盡管Lua被稱為是一種解釋型的語言,但Lua確實允許在運行源代碼之前,將源代碼預(yù)編譯成一種中間形式(類比Python的.pyc)。區(qū)別解釋型語言的主要特征在于編譯器是否是語言運行時庫的一部分,即是否有能力執(zhí)行動態(tài)生成的代碼(Lua可以通過dofile執(zhí)行Lua代碼)。
其實,dofile的核心功能是由loadfile完成的,可以這樣來定義dofile:

loadfile并不是執(zhí)行代碼,而只是編譯,返回一個函數(shù),由dofile執(zhí)行。
如果多次運行一個文件,可以只調(diào)用一次loadfile,重復(fù)調(diào)用其返回的函數(shù)即可。
另外一個函數(shù),loadstring從字符串加載代碼:
復(fù)制代碼 代碼如下:
> f = loadstring('print "hello"')
> f()
hello
考察一下loadstring代碼的執(zhí)行域
復(fù)制代碼 代碼如下:
> i = 1
> f = loadstring('i = i + 1')
> =i
1
--不要完了交互式命令行中,一行代碼默認一個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
兩次運行,都是將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
可以認為,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中其實有一個load函數(shù),后者接收一個reader function,調(diào)用其讀取代碼;
您可能感興趣的文章:- Lua中使用元表(metatable)執(zhí)行算術(shù)類元方法實例
- Lua簡介、編譯安裝教程及變量等語法介紹
- Mac平臺中編譯安裝Lua運行環(huán)境及Hello Lua實例
- Lua中編譯執(zhí)行代碼相關(guān)的函數(shù)詳解