昨天遇到另外一位獨(dú)立游戲開(kāi)發(fā)者,所以多聊了一會(huì),然后…然后就沒(méi)有看書(shū)了。(小若:借口!借口?。?br />
今天來(lái)聊聊錯(cuò)誤處理吧,不過(guò)畢竟這只是前面的章節(jié),書(shū)上的內(nèi)容似乎有點(diǎn)一筆帶過(guò)的味道。
沒(méi)關(guān)系,簡(jiǎn)單更好~
1.紅色警報(bào)——error
我們應(yīng)該能經(jīng)??吹筋愃埔韵碌腻e(cuò)誤信息:
復(fù)制代碼 代碼如下:
[LUA-print] LUA ERROR: [string "src/main.lua"]:108: [string "src/main.lua"]:89: attempt to index global ‘a(chǎn)' (a nil value)
這是在發(fā)生錯(cuò)誤時(shí)給我們的提示,通常,這代表我們的代碼不能繼續(xù)正常執(zhí)行下去了。
但你有知不知道,我們可以偽造這種錯(cuò)誤,沒(méi)錯(cuò),主動(dòng)調(diào)用error函數(shù),就會(huì)出現(xiàn)這種信息。
如下代碼:
復(fù)制代碼 代碼如下:
error("你的智商不多了,趕緊休息,恢復(fù)一下吧");
然后,運(yùn)行,輸出如下信息:
復(fù)制代碼 代碼如下:
[LUA-print] LUA ERROR: [string "src/main.lua"]:109: [string "src/main.lua"]:96: 你的智商不多了,趕緊休息,恢復(fù)一下吧
這太厲害了,以后你看誰(shuí)不爽,就往他代碼里塞上這句話吧,比如在項(xiàng)目上線前塞進(jìn)去~
言歸正傳,當(dāng)我們?cè)谡{(diào)用一個(gè)函數(shù)之前,可以先判斷即將傳遞的參數(shù)是否正常,如果不正常,我們就可以選擇直接拋出error,方便寫(xiě)代碼的過(guò)程中發(fā)現(xiàn)問(wèn)題。
比如下面的代碼:
復(fù)制代碼 代碼如下:
local name = io.read();
if name ~= "笨木頭" then
error("你是一個(gè)非常善良有愛(ài)心的人,我很喜歡你..所以,去死吧!");
end
只要發(fā)現(xiàn)輸入的內(nèi)容不是“笨木頭”,就狠狠地拋出異常。
2.偷個(gè)懶——assert
類似剛剛那種判斷錯(cuò)誤的代碼,似乎有點(diǎn)啰嗦,于是,我們可以用assert代替形如if not then的代碼。
比如上面的代碼改為:
復(fù)制代碼 代碼如下:
local name = io.read();
local result = assert(name == "笨木頭", "你是一個(gè)非常善良有愛(ài)心的人,我很喜歡你..所以,去死吧!");
如果assert的第一個(gè)參數(shù)為不為false,則返回第一個(gè)參數(shù)的值;否則,執(zhí)行error函數(shù),輸出錯(cuò)誤信息,錯(cuò)誤信息的內(nèi)容為assert的第二個(gè)參數(shù)。
輸出結(jié)果和之前是一樣的~
3.捕獲錯(cuò)誤代碼——pcall
如果在錯(cuò)誤發(fā)生時(shí),我們不希望代碼停止運(yùn)行,而是做一些緊急措施,那么,可以使用pcall捕獲錯(cuò)誤。
如以下代碼:
復(fù)制代碼 代碼如下:
function test()
print(a[1]);
end
if pcall(test) then
print("正常,呵呵");
else
print("哎,函數(shù)出錯(cuò)了,我正在幫你處理,放心吧,等我睡醒就...不是,等你睡醒就沒(méi)事了~");
end
函數(shù)test執(zhí)行的時(shí)候肯定會(huì)報(bào)錯(cuò)的,因?yàn)椴⒉淮嬖赼這個(gè)table。
使用pcall調(diào)用test函數(shù),如果test不報(bào)錯(cuò),則pcall返回ture,否則,返回false。
利用這個(gè)特性,我們就可以捕獲異常,做一些緊急處理。
運(yùn)行代碼, 輸出結(jié)果如下:
復(fù)制代碼 代碼如下:
[LUA-print] 哎,函數(shù)出錯(cuò)了,我正在幫你處理,放心吧,等我睡醒就…不是,等你睡醒就沒(méi)事了~
這緊急處理的方式還挺不錯(cuò)的,呵呵。(小若:不錯(cuò)你個(gè)頭??!這和沒(méi)處理有差別嗎?)
pcall除了會(huì)返回true或者false外,還能返回函數(shù)的錯(cuò)誤信息,如下代碼:
復(fù)制代碼 代碼如下:
function test()
print(a[1]);
end
local status, err = pcall(test);
if status then
print("正常,呵呵");
else
print("哎,函數(shù)出錯(cuò)了,我正在幫你處理,放心吧,等我睡醒就...不是,等你睡醒就沒(méi)事了~");
print(err);
end
pcall的第一個(gè)返回值和之前一樣,true或者false。
而第二個(gè)參數(shù)則是test函數(shù)拋出的錯(cuò)誤信息,執(zhí)行代碼,結(jié)果如下:
復(fù)制代碼 代碼如下:
[LUA-print] 哎,函數(shù)出錯(cuò)了,我正在幫你處理,放心吧,等我睡醒就…不是,等你睡醒就沒(méi)事了~
[LUA-print] [string "src/main.lua"]:94: attempt to index global ‘a(chǎn)' (a nil value)
4.結(jié)束
關(guān)于錯(cuò)誤處理,好像沒(méi)有什么好玩的東西,所以,就寫(xiě)這么多吧~
您可能感興趣的文章:- Lua中的異常處理pcall、xpcall、debug使用實(shí)例
- Lua函數(shù)與字符串處理簡(jiǎn)明總結(jié)
- Lua極簡(jiǎn)入門指南(三): loadfile和錯(cuò)誤處理
- Lua讀取和寫(xiě)入文件處理例子
- 淺析Lua編程中的異常處理
- lua日志文件處理代碼