Lua的編譯、執(zhí)行和調(diào)試技術(shù)介紹
dofile讀入文件編譯并執(zhí)行,真正完成功能的函數(shù)是loadfile;與dofile不同,loadfile僅僅是編譯代碼成中間碼,并且把編譯后的chunk作為函數(shù)返回。如果發(fā)生錯(cuò)誤,返回nil和錯(cuò)誤信息。我們可以這么定義dofile:
function dofile(filename)
local f = assert(loadfile(filename))
return f()
end
如果你只調(diào)用一次,可以使用dofile(filename),如果是調(diào)用多次,可以f = loadfile(filename); f();f()...
loadstring與loadfile相似,只不過他是從一個(gè)串中讀入。
lua中函數(shù)定義發(fā)生在運(yùn)行時(shí)而不是編譯時(shí)。
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ò)是人的本性,因此我們必須以最佳的方式來處理錯(cuò)誤。lua作為擴(kuò)展語言,經(jīng)常嵌入到其他應(yīng)用,當(dāng)錯(cuò)誤發(fā)生時(shí),不能簡單的crash或exit。
print "enter a number:"
n = io.read("*number")
if not n then error("invalid input") end
if not condition then error end 的組合太普遍了以至于lua專門內(nèi)建了一個(gè)函數(shù)來做這工作,這個(gè)函數(shù)就是assert。
通常,當(dāng)異常發(fā)生時(shí),你有兩個(gè)方式處理,要么返回錯(cuò)誤碼(nil),要么報(bào)錯(cuò)(error)。對(duì)于這兩種方式,并沒有固定的準(zhǔn)則來做選擇。但是我們提供通用的原則:容易避免的異常應(yīng)該報(bào)錯(cuò),否則返回異常。舉例說明:
math.sin接受個(gè)number型的弧度值,如果參數(shù)不是number,我們應(yīng)該報(bào)錯(cuò),而不是返回錯(cuò)誤碼。假設(shè)我們是返回錯(cuò)誤碼,那么我們使用就得這樣:
local res = math.sin(x)
if not res then
<error handling>
其實(shí),我們可以很容易地檢測(cè)這個(gè)異常,在調(diào)用sin之前:
if not tonumber(x) then
<error handling>
通常,我們是既不檢測(cè)sin的參數(shù),也不檢測(cè)sin的返回值。如果參數(shù)不是number,往往是我們代碼自身出問題了。這種情況下,停止執(zhí)行并報(bào)錯(cuò)是最簡單也是最實(shí)用的方式。
相反的,io.open這個(gè)函數(shù),就不存在簡單的在調(diào)用open之前就檢測(cè)出異常的方法。打開失敗可能是因?yàn)槲募淮嬖?,或?quán)限不夠。通過返回錯(cuò)誤碼,你可以采用適當(dāng)?shù)姆绞絹硖幚?,比如讓用戶輸入另一個(gè)文件名。
相關(guān)文章
Lua基礎(chǔ)教程之表(Table)學(xué)習(xí)筆記
這篇文章主要介紹了Lua基礎(chǔ)教程之表(Table)學(xué)習(xí)筆記,本文來自個(gè)人總結(jié),需要的朋友可以參考下2014-09-09讓你的python代碼更加pythonic(簡練、明確、優(yōu)雅)
這篇文章主要介紹了讓你的python代碼更加pythonic(簡練、明確、優(yōu)雅),本文講解的是一種讓代碼更加清晰、簡練、明確、優(yōu)雅的書寫方法,需要的朋友可以參考下2014-10-10Lua中實(shí)現(xiàn)遞歸刪除一個(gè)文件夾
這篇文章主要介紹了Lua中實(shí)現(xiàn)遞歸刪除一個(gè)文件夾,本文給出了使用C++和使用純LUA兩種方式實(shí)現(xiàn),需要的朋友可以參考下2015-01-01