鍍金池/ 教程/ C/ Lua錯(cuò)誤處理
Lua邏輯運(yùn)算符
Lua其他運(yùn)算符
Lua協(xié)同程序
Lua break語(yǔ)句
Lua運(yùn)算符
Lua面向?qū)ο?/span>
Lua教程
Lua函數(shù)
Lua數(shù)據(jù)庫(kù)/MySQL操作
Lua關(guān)系運(yùn)算符
Lua錯(cuò)誤處理
Lua數(shù)據(jù)類型
Lua嵌套循環(huán)
Lua變量
Lua基本語(yǔ)法
Lua字符串
Lua for循環(huán)
Lua if語(yǔ)句嵌套
Lua運(yùn)算符優(yōu)先級(jí)
Lua Web編程
Lua while循環(huán)
Lua開發(fā)環(huán)境
Lua if...else語(yǔ)句
Lua標(biāo)準(zhǔn)庫(kù)
Lua游戲編程
Lua if語(yǔ)句
Lua算術(shù)運(yùn)算符
Lua表格
Lua決策
Lua文件I/O
Lua循環(huán)
Lua數(shù)組
Lua元表
Lua repeat...until循環(huán)
Lua迭代器
Lua調(diào)試
Lua模塊
Lua垃圾收集

Lua錯(cuò)誤處理

需要進(jìn)行錯(cuò)誤處理

錯(cuò)誤處理是必要的,因?yàn)檎鎸?shí)世界中的操作通常需要使用復(fù)雜的操作,包括文件操作,數(shù)據(jù)庫(kù)事務(wù)和web服務(wù)調(diào)用。沒人關(guān)心錯(cuò)誤的業(yè)務(wù),涉及保密信息或金錢交易時(shí)造成大的損失。

在任何編程,總是有錯(cuò)誤處理的要求。錯(cuò)誤可以是兩種類型,其中包括,

  • 語(yǔ)法錯(cuò)誤

  • 運(yùn)行時(shí)錯(cuò)誤

語(yǔ)法錯(cuò)誤

因使用不當(dāng)造成的各種程序組件,如運(yùn)算符和表達(dá)式中出現(xiàn)語(yǔ)法錯(cuò)誤。一個(gè)簡(jiǎn)單的例子中的語(yǔ)法錯(cuò)誤如下所示。

a == 2

如你所知,有使用單一等于和雙等于之間的差異。使用一個(gè)替代其他可導(dǎo)致錯(cuò)誤。等于是指分配,比較。同樣,表示和有其預(yù)定實(shí)施這些方式的功能。

另一例為語(yǔ)法錯(cuò)誤如下所示。

for a= 1,10
   print(a)
end

當(dāng)我們運(yùn)行上面的程序,會(huì)得到下面的輸出。

lua: test2.lua:2: 'do' expected near 'print'

語(yǔ)法錯(cuò)誤更容易處理程序不是運(yùn)行時(shí)錯(cuò)誤,因?yàn)?,Lua解釋更清楚地定位誤差比的情況下運(yùn)行時(shí)錯(cuò)誤。從上面的錯(cuò)誤,我們可以很容易知道,添加do語(yǔ)句之前print語(yǔ)句,每個(gè)Lua結(jié)構(gòu)所需要的。

運(yùn)行時(shí)錯(cuò)誤

如果運(yùn)行時(shí)錯(cuò)誤,程序執(zhí)行成功,但它可能會(huì)導(dǎo)致在輸入或處理不當(dāng),功能運(yùn)行時(shí)錯(cuò)誤是由于錯(cuò)誤。一個(gè)簡(jiǎn)單的例子來(lái)顯示的運(yùn)行時(shí)間誤差如下所示。

function add(a,b)
   return a+b
end

add(10)

當(dāng)我們建立的程序,它會(huì)成功地建立并運(yùn)行。一旦運(yùn)行,它會(huì)運(yùn)行并顯示一個(gè)運(yùn)行時(shí)錯(cuò)誤。

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ā)生因不是通過兩個(gè)變量的運(yùn)行時(shí)錯(cuò)誤。 b參數(shù)的預(yù)期值是nil,并產(chǎn)生一個(gè)錯(cuò)誤。

維護(hù)和故障功能

為了處理錯(cuò)誤時(shí),我們經(jīng)常使用的兩個(gè)函數(shù)斷言和錯(cuò)誤。一個(gè)簡(jiǎn)單的例子如下所示。

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)我們運(yùn)行上面的程序,會(huì)得到下面的錯(cuò)誤輸出。

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]: ?

錯(cuò)誤error (message [, level])結(jié)束最后一個(gè)被叫保護(hù)功能,并返回信息的錯(cuò)誤消息。這個(gè)函數(shù)的錯(cuò)誤不會(huì)返回。通常情況下,錯(cuò)誤增加了約在郵件的開頭錯(cuò)誤位置的一些信息。level參數(shù)指定如何得到錯(cuò)誤的位置。級(jí)別1(默認(rèn)值),錯(cuò)誤位置是誤差函數(shù)被調(diào)用。 2級(jí)分錯(cuò)誤的地方調(diào)用錯(cuò)誤的函數(shù)被調(diào)用等等。傳遞一個(gè)0級(jí)可避免增加錯(cuò)誤的位置信息的消息。

pcall和xpcall

在 Lua 編程,以避免引發(fā)這些錯(cuò)誤和處理錯(cuò)誤,需要使用的功能 pcall 或 xpcall。

pcall (f, arg1, ...)函數(shù)調(diào)用保護(hù)模式所要求的功能。如果函數(shù)f 出現(xiàn)了一些錯(cuò)誤,但不會(huì)引發(fā)錯(cuò)誤。它只是返回錯(cuò)誤的狀態(tài)。使用pcall 一個(gè)簡(jiǎn)單的例子如下所示。

function myfunction ()
   n = n/nil
end

if pcall(myfunction) then
   print("Success")
else
	print("Failure")
end

當(dāng)我們運(yùn)行上面的程序,會(huì)得到下面的輸出。

Failure

xpcall (f, err) 函數(shù)調(diào)用所要求的功能,還設(shè)置了錯(cuò)誤處理程序。f 任何錯(cuò)誤不傳播; 相反,xpcall 捕獲錯(cuò)誤,要求與原來(lái)的錯(cuò)誤對(duì)象Err函數(shù),并返回一個(gè)狀態(tài)代碼。

一個(gè)簡(jiǎn)單的例子為 xpcall 如下所示。

function myfunction ()
   n = n/nil
end

function myerrorhandler( err )
   print( "ERROR:", err )
end

status = xpcall( myfunction, myerrorhandler )
print( status)

當(dāng)我們運(yùn)行上面的程序,會(huì)得到下面的輸出。

ERROR:	test2.lua:2: attempt to perform arithmetic on global 'n' (a nil value)
false

作為一個(gè)程序員最重要的是要確保正確的錯(cuò)誤處理。使用錯(cuò)誤處理可以確保超出邊界條件意想不到的條件,而不會(huì)干擾該程序的用戶進(jìn)行處理。