盡管Lua被稱為是一種解釋型的語言,但Lua確實(shí)允許在運(yùn)行源代碼之前,將源代碼預(yù)編譯成一種中間形式(類比Python的.pyc)。區(qū)別解釋型語言的主要特征在于編譯器是否是語言運(yùn)行時(shí)庫的一部分,即是否有能力執(zhí)行動態(tài)生成的代碼(Lua可以通過dofile執(zhí)行Lua代碼)。
其實(shí),dofile的核心功能是由loadfile完成的,可以這樣來定義dofile:
loadfile并不是執(zhí)行代碼,而只是編譯,返回一個(gè)函數(shù),由dofile執(zhí)行。
如果多次運(yùn)行一個(gè)文件,可以只調(diào)用一次loadfile,重復(fù)調(diào)用其返回的函數(shù)即可。
另外一個(gè)函數(shù),loadstring從字符串加載代碼:
復(fù)制代碼 代碼如下:
> f = loadstring('print "hello"')
> f()
hello
考察一下loadstring代碼的執(zhí)行域
復(fù)制代碼 代碼如下:
> i = 1
> f = loadstring('i = i + 1')
> =i
1
--不要完了交互式命令行中,一行代碼默認(rèn)一個(gè)block
> f = loadstring('i=i+1')
> do
>> local i =1
>> f()
>> print(i)
>> end
1
> do
>> local i = 1
>> local f = loadstring('i=i+1')
>> f()
>> print(i)
>> end
1
兩次運(yùn)行,都是將global中的i加1.
可以這樣理解f:
復(fù)制代碼 代碼如下:
function f()
i = i+1
end
但如果直接替換,其結(jié)果并不一致。
復(fù)制代碼 代碼如下:
> do
>> local i =1
>> function f()
>> i = i + 1
>> end
>> f()
>> print(i)
>> end
2
可以認(rèn)為,loadstring編譯出的函數(shù),會關(guān)聯(lián)global scope,因而不會表現(xiàn)出閉包的特性,故而,應(yīng)該盡量不使用這種方式!
另外,如果語法有誤,那么loadstring返回nil。
可以使用assert(loadstring(s))()的方式。
如果參數(shù)不是nil/false,返回參數(shù),否則assert error;
深究一下loadfile和loadstring就會知道,Lua中其實(shí)有一個(gè)load函數(shù),后者接收一個(gè)reader function,調(diào)用其讀取代碼;
您可能感興趣的文章:- Lua中使用元表(metatable)執(zhí)行算術(shù)類元方法實(shí)例
- Lua簡介、編譯安裝教程及變量等語法介紹
- Mac平臺中編譯安裝Lua運(yùn)行環(huán)境及Hello Lua實(shí)例
- Lua中編譯執(zhí)行代碼相關(guān)的函數(shù)詳解