需要進(jìn)行錯誤處理
錯誤處理是必要的,因為真實世界中的操作通常需要使用復(fù)雜的操作,包括文件操作,數(shù)據(jù)庫事務(wù)和web服務(wù)調(diào)用。沒人關(guān)心錯誤的業(yè)務(wù),涉及保密信息或金錢交易時造成大的損失。
在任何編程,總是有錯誤處理的要求。錯誤可以是兩種類型,其中包括,
語法錯誤
因使用不當(dāng)造成的各種程序組件,如運算符和表達(dá)式中出現(xiàn)語法錯誤。一個簡單的例子中的語法錯誤如下所示。
復(fù)制代碼 代碼如下:
a == 2
如你所知,有使用單一等于和雙等于之間的差異。使用一個替代其他可導(dǎo)致錯誤。等于是指分配,比較。同樣,表示和有其預(yù)定實施這些方式的功能。
另一例為語法錯誤如下所示。
復(fù)制代碼 代碼如下:
for a= 1,10
print(a)
end
當(dāng)我們運行上面的程序,會得到下面的輸出。
復(fù)制代碼 代碼如下:
lua: test2.lua:2: 'do' expected near 'print'
語法錯誤更容易處理程序不是運行時錯誤,因為,Lua解釋更清楚地定位誤差比的情況下運行時錯誤。從上面的錯誤,我們可以很容易知道,添加do語句之前print語句,每個Lua結(jié)構(gòu)所需要的。
運行時錯誤
如果運行時錯誤,程序執(zhí)行成功,但它可能會導(dǎo)致在輸入或處理不當(dāng),功能運行時錯誤是由于錯誤。一個簡單的例子來顯示的運行時間誤差如下所示。
復(fù)制代碼 代碼如下:
function add(a,b)
return a+b
end
add(10)
當(dāng)我們建立的程序,它會成功地建立并運行。一旦運行,它會運行并顯示一個運行時錯誤。
復(fù)制代碼 代碼如下:
lua: test2.lua:2: attempt to perform arithmetic on local 'b' (a nil value)
stack traceback:
test2.lua:2: in function 'add'
test2.lua:5: in main chunk
[C]: ?
發(fā)生因不是通過兩個變量的運行時錯誤。 b參數(shù)的預(yù)期值是nil,并產(chǎn)生一個錯誤。
維護(hù)和故障功能
為了處理錯誤時,我們經(jīng)常使用的兩個函數(shù)斷言和錯誤。一個簡單的例子如下所示。
復(fù)制代碼 代碼如下:
local function add(a,b)
assert(type(a) == "number", "a is not a number")
assert(type(b) == "number", "b is not a number")
return a+b
end
add(10)
當(dāng)我們運行上面的程序,會得到下面的錯誤輸出。
復(fù)制代碼 代碼如下:
lua: test2.lua:3: b is not a number
stack traceback:
[C]: in function 'assert'
test2.lua:3: in function 'add'
test2.lua:6: in main chunk
[C]: ?
錯誤error (message [, level])結(jié)束最后一個被叫保護(hù)功能,并返回信息的錯誤消息。這個函數(shù)的錯誤不會返回。通常情況下,錯誤增加了約在郵件的開頭錯誤位置的一些信息。level參數(shù)指定如何得到錯誤的位置。級別1(默認(rèn)值),錯誤位置是誤差函數(shù)被調(diào)用。 2級分錯誤的地方調(diào)用錯誤的函數(shù)被調(diào)用等等。傳遞一個0級可避免增加錯誤的位置信息的消息。
pcall和xpcall
在 Lua 編程,以避免引發(fā)這些錯誤和處理錯誤,需要使用的功能 pcall 或 xpcall。
pcall (f, arg1, ...)函數(shù)調(diào)用保護(hù)模式所要求的功能。如果函數(shù)f 出現(xiàn)了一些錯誤,但不會引發(fā)錯誤。它只是返回錯誤的狀態(tài)。使用pcall 一個簡單的例子如下所示。
復(fù)制代碼 代碼如下:
function myfunction ()
n = n/nil
end
if pcall(myfunction) then
print("Success")
else
print("Failure")
end
當(dāng)我們運行上面的程序,會得到下面的輸出。
復(fù)制代碼 代碼如下:
Failure
xpcall (f, err) 函數(shù)調(diào)用所要求的功能,還設(shè)置了錯誤處理程序。f 任何錯誤不傳播; 相反,xpcall 捕獲錯誤,要求與原來的錯誤對象Err函數(shù),并返回一個狀態(tài)代碼。
一個簡單的例子為 xpcall 如下所示。
復(fù)制代碼 代碼如下:
function myfunction ()
n = n/nil
end
function myerrorhandler( err )
print( "ERROR:", err )
end
status = xpcall( myfunction, myerrorhandler )
print( status)
當(dāng)我們運行上面的程序,會得到下面的輸出。
復(fù)制代碼 代碼如下:
ERROR: test2.lua:2: attempt to perform arithmetic on global 'n' (a nil value)
false
作為一個程序員最重要的是要確保正確的錯誤處理。使用錯誤處理可以確保超出邊界條件意想不到的條件,而不會干擾該程序的用戶進(jìn)行處理。
您可能感興趣的文章:- Lua中簡單的錯誤處理實例
- Lua中的異常處理pcall、xpcall、debug使用實例
- Lua函數(shù)與字符串處理簡明總結(jié)
- Lua極簡入門指南(三): loadfile和錯誤處理
- Lua讀取和寫入文件處理例子
- lua日志文件處理代碼