全局变量是不好的,这会以任何方式提高性能吗?
2013-2-14 18:20:23
收藏:0
阅读:179
评论:2
我正在LuaJIT中工作,我的所有库和其他东西都存储在"foo"中,如下所示:
foo = {}; -- The only global variable
foo.print = {};
foo.print.say = function(msg) print(msg) end;
foo.print.say("test")
我想知道,使用元表并保持所有库本地是否有帮助?或者没有关系。我想到的是这个:
foo = {};
local libraries = {};
setmetatable(foo, {
__index = function(t, key)
return libraries[key];
end
});
-- A function to create a new library.
function foo.NewLibrary(name)
libraries[name] = {};
return libraries[name];
end;
local printLib = foo.NewLibrary("print");
printLib.say = function(msg) print(msg) end;
-- Other file:
foo.print.say("test")
我现在没有工具来对此进行基准测试,但是将库的实际内容保存在本地表中是否会增加性能?即使是稍微的?
我希望自己表达清楚了,基本上我想知道的是:从性能上讲,第二种方法更好吗?
如果有人可以链接/提供关于Lua中如何处理全局变量的详细说明,那就太好了。
点赞
用户646619
以下是我编写模块的方式:
-- foo.lua
local MyLib = {}
function MyLib.foo()
...
end
return MyLib
-- bar.lua
local MyLib = require("foo.lua")
MyLib.foo()
请注意,return MyLib 不在一个函数中。require 捕捉这个返回值并将其用作库。这样,就没有全局变量了。
2013-09-05 21:49:37
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
你确实有。
local start = os.clock() for i=1,100000 do -- 调整迭代次数以适应情况 -- 要测试的内容 end print(os.clock() - start)在性能方面,你几乎总是需要进行基准测试。
与代码的第一个版本相比?从理论上讲不会。
你的第一个例子(去掉不必要的麻烦):
foo = {} foo.print = {} function foo.print.say(msg) print(msg) end要调用你的打印函数需要三个表查找:
foo表foo.print表。你的第二个例子:
local libraries = {} libraries.print = {} function libraries.print.say(msg) print(msg) end foo = {} setmetatable(foo, { __index = function(t, key) return libraries[key]; end });现在要调用你的打印函数需要五个表查找和其他额外的工作:
foo表foo是否有一个元表,发现有一个librariesprint表其中一些额外的工作是在 C 代码中完成的,因此它比如果所有内容都在 Lua 中实现要快,但肯定需要更多时间。
使用我上面展示的循环进行基准测试,第一个版本在普通的 Lua 中大约是第二个版本的两倍。在 LuaJIT 中,两者的速度完全相同。显然,LuaJIT 在运行时优化了差异(这相当令人印象深刻)。这只是说明了基准测试的重要性。
附注:Lua 允许您提供一个表作为“_ _ index”,这将导致与您的代码等效的查找:
setmetatable(foo, { __index = function(t, key) return libraries[key] end } )因此,您可以编写:
setmetatable(foo, { __index = libraries })这也恰巧更快。