dofile讀入文件編譯并執(zhí)行,真正完成功能的函數(shù)是loadfile;與dofile不同,loadfile僅僅是編譯代碼成中間碼,并且把編譯后的chunk作為函數(shù)返回。如果發(fā)生錯(cuò)誤,返回nil和錯(cuò)誤信息。我們可以這么定義dofile:
復(fù)制代碼 代碼如下:
function dofile(filename)
local f = assert(loadfile(filename))
return f()
end
如果你只調(diào)用一次,可以使用dofile(filename),如果是調(diào)用多次,可以f = loadfile(filename); f();f()...
loadstring與loadfile相似,只不過(guò)他是從一個(gè)串中讀入。
lua中函數(shù)定義發(fā)生在運(yùn)行時(shí)而不是編譯時(shí)。
復(fù)制代碼 代碼如下:
f = loadstring("i=i+1")
與f = function() i = i+1 end等價(jià)。但loadstring不關(guān)心詞法范圍:
i = 33
local i = 0;
f = loadstring("i=i+1")
g = function() i = i+1 end
g使用的是局部變量i,而f使用的是全局變量i,因?yàn)閒總是在全局環(huán)境下編譯。
犯錯(cuò)是人的本性,因此我們必須以最佳的方式來(lái)處理錯(cuò)誤。lua作為擴(kuò)展語(yǔ)言,經(jīng)常嵌入到其他應(yīng)用,當(dāng)錯(cuò)誤發(fā)生時(shí),不能簡(jiǎn)單的crash或exit。
復(fù)制代碼 代碼如下:
print "enter a number:"
n = io.read("*number")
if not n then error("invalid input") end
if not condition then error end 的組合太普遍了以至于lua專門(mén)內(nèi)建了一個(gè)函數(shù)來(lái)做這工作,這個(gè)函數(shù)就是assert。
通常,當(dāng)異常發(fā)生時(shí),你有兩個(gè)方式處理,要么返回錯(cuò)誤碼(nil),要么報(bào)錯(cuò)(error)。對(duì)于這兩種方式,并沒(méi)有固定的準(zhǔn)則來(lái)做選擇。但是我們提供通用的原則:容易避免的異常應(yīng)該報(bào)錯(cuò),否則返回異常。舉例說(shuō)明:
math.sin接受個(gè)number型的弧度值,如果參數(shù)不是number,我們應(yīng)該報(bào)錯(cuò),而不是返回錯(cuò)誤碼。假設(shè)我們是返回錯(cuò)誤碼,那么我們使用就得這樣:
復(fù)制代碼 代碼如下:
local res = math.sin(x)
if not res then
error handling>
其實(shí),我們可以很容易地檢測(cè)這個(gè)異常,在調(diào)用sin之前:
復(fù)制代碼 代碼如下:
if not tonumber(x) then
error handling>
通常,我們是既不檢測(cè)sin的參數(shù),也不檢測(cè)sin的返回值。如果參數(shù)不是number,往往是我們代碼自身出問(wèn)題了。這種情況下,停止執(zhí)行并報(bào)錯(cuò)是最簡(jiǎn)單也是最實(shí)用的方式。
相反的,io.open這個(gè)函數(shù),就不存在簡(jiǎn)單的在調(diào)用open之前就檢測(cè)出異常的方法。打開(kāi)失敗可能是因?yàn)槲募淮嬖?,或?quán)限不夠。通過(guò)返回錯(cuò)誤碼,你可以采用適當(dāng)?shù)姆绞絹?lái)處理,比如讓用戶輸入另一個(gè)文件名。