加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Lua 编译

发布时间:2020-12-14 22:06:43 所属栏目:大数据 来源:网络整理
导读:尽管Lua被称为是一种解释型的语言,但Lua确实允许在运行源代码之前,将源代码预编译成一种中间形式(类比Python的.pyc)。区别解释型语言的主要特征在于编译器是否是语言运行时库的一部分,即是否有能力执行动态生成的代码(Lua可以通过 dofile 执行Lua代码

尽管Lua被称为是一种解释型的语言,但Lua确实允许在运行源代码之前,将源代码预编译成一种中间形式(类比Python的.pyc)。区别解释型语言的主要特征在于编译器是否是语言运行时库的一部分,即是否有能力执行动态生成的代码(Lua可以通过dofile执行Lua代码)。

? ?

其实,dofile的核心功能是由loadfile完成的,可以这样来定义dofile:

? ?

loadfile并不是执行代码,而只是编译,返回一个函数,由dofile执行。

如果多次运行一个文件,可以只调用一次loadfile,重复调用其返回的函数即可。

? ?

另外一个函数,loadstring从字符串加载代码:

> f = loadstring('print "hello"')

> f()

hello

? ?

考察一下loadstring代码的执行域

> 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:

function f()

i = i+1

end

但如果直接替换,其结果并不一致。

> do

>> local i =1

>> function f()

>> i = i + 1

>> end

>> f()

>> print(i)

>> end

2

可以认为,loadstring编译出的函数,会关联global scope,因而不会表现出闭包的特性,故而,应该尽量不使用这种方式!

? ?

另外,如果语法有误,那么loadstring返回nil。

可以使用assert(loadstring(s))()的方式。

如果参数不是nil/false,返回参数,否则assert error;

? ?

深究一下loadfile和loadstring就会知道,Lua中其实有一个load函数,后者接收一个reader function,调用其读取代码;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读