青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

loop_in_codes

低調做技術__歡迎移步我的獨立博客 codemaro.com 微博 kevinlynx

tolua的tolua_toxxx系列API設計

原文鏈接:http://codemacro.com/2012/05/10/tolua-api/

我們使用tolua++手工綁定c/c++接口到lua中,在綁定的接口實現里,就需要取出傳入的參數。tolua++中提供了一系列tolua_toxxx函數,例如:

lua_Number tolua_tonumber(lua_State *L, int narg, lua_Number def)
const char *tolua_tostring(lua_State *L, int narg, const char *def)

這些函數都有一個def參數。乍一看,這些函數使用起來很簡單。傳入lua_State,傳入參數在棧中的位置,然后再傳一個失敗后返回的默認值。

我重點要說的是這里這個失敗,按正常程序員的理解,針對lua而言,什么情況下算失敗呢?lua語言里函數參數支持不傳,此時實參為nil,將nil轉換為一個c類型必然失敗;參數類型不正確算不算失敗?你傳一個user data,c里按數字來取,這也算失敗。

這么簡單的API還需要多糾結什么呢?然后我們浩浩蕩蕩地寫了上百個接口,什么tolua_tostring/tolua_tonumber的使用少說也有500了吧?

然后有一天,服務器宕機了,空指針:

/* 失敗返回"",還能省空指針的判斷 */
const char *name = tolua_tostring(L, 1, "");
if (name[0] == '\0') { /* 空串總得判斷吧 */
 ...
}

跟蹤后發現,腳本里傳入的是nil,這里的name取出來是NULL,而不是”“(的地址)。然后吐槽了一下這個API,辛苦地修改了所有類似代碼,增加對空指針的判斷。我沒有多想。

故事繼續,有一天服務器雖然沒宕機,但功能不正常了:

float angle = (float) tolua_tonumber(L, 1, 2 * PI);
...

這個意思是,這個函數的參數1默認是2*PI,什么是默認?lua里某函數參數不傳,或傳nil就是使用默認。因為不傳的話,這個實參本身就是nil。但,tolua_tonumber的行為不是這樣的,它的實現真是偷懶:

TOLUA_API lua_Number tolua_tonumber (lua_State* L, int narg, lua_Number def)
{
 return lua_gettop(L)<abs(narg) ? def : lua_tonumber(L,narg);
}
TOLUA_API const char* tolua_tostring (lua_State* L, int narg, const char* def)
{
 return lua_gettop(L)<abs(narg) ? def : lua_tostring(L,narg);
}

意思是,只有當你不傳的時候,它才返回默認值,否則就交給lua的API來管,而lua這些API是不支持應用層的默認參數的,對于lua_tonumber錯誤時就返回0,lua_tostring錯誤時就返回NULL。

這種其行為和其帶來的common sense不一致的API設計,實在讓人蛋疼。什么是common sense呢?就像一個UI庫里的按鈕,我們都知道有click事件,hover事件,UI庫的文檔甚至都不需要解釋什么是click什么是hover,因為大家看到這個東西,就有了共識,無需廢話,這就是common sense。就像tolua的這些API,非常普通,大家一看都期待在意外情況下你能返回def值。但它竟然不是。實在不行,你可以模仿lua的check系列函數的實現嘛:

LUALIB_API lua_Number luaL_checknumber (lua_State *L, int narg) {
 lua_Number d = lua_tonumber(L, narg);
 if (d == 0 && !lua_isnumber(L, narg)) /* avoid extra test when d is not 0 */
 tag_error(L, narg, LUA_TNUMBER);
 return d;
}

即,根本不用去檢查棧問題,直接在lua_tonumber之后再做包裝檢查。何況,lua需要你去檢查棧嗎?當你訪問了棧外的元素時,lua會自動返回一個全局常量luaO_nilobject:

static TValue *index2adr(lua_State *L, int idx) {
 ...
 if (o >= L->top) return cast(TValue*, luaO_nilobject);
}

另,程序悲劇也來源于臆想。

posted on 2012-05-10 15:38 Kevin Lynx 閱讀(5313) 評論(0)  編輯 收藏 引用 所屬分類: c/c++lua

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产日韩在线| 伊人成人网在线看| 久久只精品国产| 欧美不卡一区| 国产精品亚洲综合久久| 一区三区视频| 亚洲影视在线| 日韩天堂av| 久久国产精品亚洲77777| 欧美激情va永久在线播放| 国产偷久久久精品专区| 亚洲精品一二区| 久久国产黑丝| 亚洲尤物在线视频观看| 欧美1区2区视频| 亚洲第一中文字幕在线观看| 亚洲性视频网址| 欧美寡妇偷汉性猛交| 久久精品成人| 国产精品久久夜| 欧美国产日韩精品| 亚洲日韩中文字幕在线播放| 欧美一区1区三区3区公司| 国产精品99久久99久久久二8 | 亚洲视频福利| 欧美14一18处毛片| 亚洲国产一区在线观看| 久久精品在线| 亚洲国产精品ⅴa在线观看| 久久精品女人| 狠狠久久婷婷| 久久久久国色av免费看影院 | 亚洲午夜激情网页| 欧美精品123区| 国产欧美一区二区精品仙草咪 | 亚洲一区一卡| 国产精品综合| 亚洲欧美日产图| 亚洲毛片av| 欧美激情导航| 一本久道综合久久精品| 艳女tv在线观看国产一区| 欧美本精品男人aⅴ天堂| 免费国产自线拍一欧美视频| 在线播放日韩| 亚洲免费在线电影| 亚洲欧美一区二区三区极速播放 | 亚洲精品专区| 欧美婷婷久久| 亚洲免费视频在线观看| 午夜一区二区三区在线观看| 国产欧美精品va在线观看| 一区二区激情| 欧美一区=区| 一区二区三区在线免费视频 | 午夜精品一区二区三区电影天堂| 国产精品午夜在线观看| 蜜桃久久av| 欧美韩日一区| 亚洲韩日在线| 日韩视频一区二区| 欧美视频三区在线播放| 狠狠久久婷婷| 裸体歌舞表演一区二区| 日韩天堂在线观看| 一区二区国产在线观看| 亚洲国内精品在线| 欧美精品乱码久久久久久按摩| 亚洲伊人观看| 久久久久久久久久久成人| 欧美亚洲综合久久| 欧美特黄一区| 99re66热这里只有精品3直播| 国产精品超碰97尤物18| 日韩一级不卡| 亚洲欧美国产精品桃花| 欧美日韩中字| 亚洲曰本av电影| 久久亚洲风情| 在线日韩欧美视频| 亚洲毛片一区| 欧美一区二区三区四区夜夜大片 | 免费成人激情视频| 欧美片在线观看| 亚洲美女黄网| 99精品福利视频| 亚洲欧美视频在线观看视频| 久久综合九色九九| 欧美岛国在线观看| 久久久999精品视频| 久久夜色精品国产| 亚洲自拍电影| 亚洲免费av片| 一区视频在线播放| 亚洲永久免费观看| 欧美不卡视频一区| 99视频有精品| 亚洲在线一区| 亚洲欧美日韩精品久久| 欧美一区二区在线免费播放| 日韩一级裸体免费视频| 久久精品视频免费观看| 免费成人黄色片| 久久精品国产免费观看| 欧美一区二区三区在线播放| 久久久久久久波多野高潮日日 | 久久精品人人做人人综合| 国产一区二区无遮挡| 欧美激情视频一区二区三区在线播放| 欧美性生交xxxxx久久久| 欧美高清视频在线| 国产精品一区二区在线观看网站| 欧美大秀在线观看| 在线日韩日本国产亚洲| 久久国产欧美日韩精品| 亚洲一二三区精品| 欧美成人午夜剧场免费观看| 久久久久国产一区二区三区| 欧美日韩免费在线观看| 亚洲欧美激情一区二区| 欧美一区中文字幕| 欧美色播在线播放| 久久久精品欧美丰满| 一区二区三区在线免费视频| 国产人妖伪娘一区91| 亚洲一区999| 亚洲欧美视频在线| 欧美一区二区精品在线| 久久精品欧美| 欧美激情黄色片| 91久久精品国产91久久| av成人免费在线观看| 国产精品久久久久一区二区三区| 国产精品影院在线观看| 一区二区三区日韩精品| 亚洲精品在线观| 欧美专区第一页| 国产精品久久久久久久久| 国产一区二区三区四区五区美女 | 国产精品久久久久一区二区| 99精品欧美一区二区三区综合在线| 亚洲精品激情| 欧美黑人在线观看| 亚洲精品美女91| 亚洲综合色婷婷| 国产精品日韩专区| 欧美一区二区私人影院日本| 宅男噜噜噜66一区二区| 国产精品嫩草99av在线| 性色av香蕉一区二区| 久久综合综合久久综合| 亚洲二区视频在线| 欧美日韩亚洲一区二区三区| 久久久久久自在自线| 亚洲精品在线一区二区| 久久国内精品自在自线400部| 99在线精品观看| 国产欧美视频在线观看| 欧美日韩国产综合视频在线观看| 亚洲视频高清| 欧美国产精品va在线观看| 欧美自拍丝袜亚洲| 亚洲国产精品成人一区二区| 欧美日韩国语| 欧美成人免费在线观看| 亚洲午夜电影在线观看| 亚洲国产精品传媒在线观看| 午夜久久久久| 在线欧美小视频| 免费成人黄色片| 老司机免费视频一区二区| 夜夜精品视频| 亚洲精品久久久蜜桃 | 久久久久五月天| 亚洲精品影院在线观看| 欧美激情二区三区| 欧美在线视频免费| 亚洲欧洲日本国产| 久久一综合视频| 在线精品视频一区二区| 欧美黑人在线播放| 美女被久久久| 一区二区免费在线观看| 日韩午夜电影| 国产日韩欧美制服另类| 麻豆91精品91久久久的内涵| 久久国产精品72免费观看| 日韩午夜精品| 亚洲人久久久| 国产在线播精品第三| 国产精品久久久久免费a∨| 久久综合影视| 99精品国产热久久91蜜凸| 亚洲精品一区二区三区蜜桃久 | 亚洲第一区在线观看| 欧美一区二区精美| 午夜精品免费视频| 一区二区三区欧美| 国产欧美一区二区色老头 | 亚洲免费中文字幕|