创建通用 Lua 函数的本地副本有什么价值,比如print()
,pairs()
或ipairs()
?
例子:
local _print = print
local _pairs = pairs
local _ipairs = ipairs
for i, v in _ipairs(someTable) do
_print(v)
end
我已经看到一些使用它编写的 Lua 并且想知道这样做是否有任何好处(性能或其他)?
创建通用 Lua 函数的本地副本有什么价值,比如print()
,pairs()
或ipairs()
?
例子:
local _print = print
local _pairs = pairs
local _ipairs = ipairs
for i, v in _ipairs(someTable) do
_print(v)
end
我已经看到一些使用它编写的 Lua 并且想知道这样做是否有任何好处(性能或其他)?
主要动机可能是性能,因为访问全局变量需要哈希表查找,而访问局部变量则不需要。但是,您应该测量程序中的差异。不要过度。
请注意,您不需要使用不同的名称:您可以编写local print=print
etc 以便程序的其余部分实际上不需要知道这些变量是局部变量还是全局变量。
最后,当您将全局变量的值保存到本地变量中时,存在语义上的差异:您正在进行早期绑定;如果您的程序调用使用相同功能的外部模块,它将使用当前值,而不是您拥有的冻结值。换句话说,以后对 say 的重新定义print
不会影响你。
有关性能的详细讨论,请阅读Lua Programmming Gems的第 2 章。
定义通用功能的本地副本的另一个动机是重新定义它们并仍然保留原始功能。
这是Lua Programing Gems中的一个示例:
访问外部局部变量(即封闭函数的局部变量)不如访问局部变量快,但仍比访问全局变量快。考虑下一个片段:
function foo (x)
for i = 1, 1000000 do
x = x + math.sin(i)
end
return x
end
print(foo(10))
我们可以通过在函数 foo 之外声明一次 sin 来优化它:
local sin = math.sin
function foo (x)
for i = 1, 1000000 do
x = x + sin(i)
end
return x
end
print(foo(10))
第二个代码的运行速度比原始代码快 30%