lua的编译、调试、运行

我们把Lua当作解释型语言,但是Lua会首先把代码预编译成中间码然后再执行(很多解释型语言都是这么做的)。在解释型语言中存在编译阶段听起来不合适,然而,解释型语言的特征不在于他们是否被编译,而是编译器是语言运行时的一部分,所以,执行编译产生的中间码速度会更快。我们可以说函数dofile的存在就是说明可以将Lua作为一种解释型语言被调用。
dofile实际上是一个辅助的函数。真正完成功能的函数是loadfile;与dofile不同的是loadfile编译代码成中间码并且返回编译后的chunk作为一个函数,而不执行代码;另外loadfile不会抛出错误信息而是返回错误代。.我们可以这样定义dofile

loadfile——只编译,不运行
loadfile故名思议,它只会加载文件,编译代码,不会运行文件里的代码。
比如,我们有一个hellofile.lua文件

print(“hello”);
function hehe()
    print(“hello”);
end

这个文件里有一句代码,和一个函数。试试用loadfile加载这个文件,如下代码

loadfile("hellofile.lua");
print("end");  --结果只是输出end,故说明它是不会执行代码的

dofile——执行
很明显,dofile就是会执行代码的家伙了,如下代码

 dofile("E:/Android/wordspace_cocosIDERc0/CocosLuaTest/src/hellofile.lua");
 print("end"); --结果输出hellofile.lua中的代码和end

require函数
Lua提供高级的require函数来加载运行库。粗略的说require和dofile完成同样的功能但有两点不同:
1. require会搜索目录加载文件
2. require会判断是否文件已经加载避免重复加载同一文件。由于上述特征,require在Lua中是加载库的更好的函数。require在第一次加载文件的时候,会执行里面的代码。第二次之后,再次加载文件,则不会重复执行了。换句话说,它会保存已经加载过的文件,不会重复加载
测试代码如下:

   for i = 1, 2, 1 do
        require("hellofile.lua");
    end
    print("end");
//为了说明这种情况,我刻意调用了两次require,输出结果只是hello和end
发布了46 篇原创文章 · 获赞 13 · 访问量 3万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章