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

lua:关于本地范围的模块导入

发布时间:2020-12-14 21:49:53 所属栏目:大数据 来源:网络整理
导读:有两个脚本文件包含以下脚本 //parent.luafunction scope() local var = "abc" require "child"end//child.luaprint(var) 这样,child.lua将打印一个nil值,因为parent.lua中的作用域不会将其本地功能公开给模块.我认为会这样,因为在此范围内和var声明之后声明
有两个脚本文件包含以下脚本

//parent.lua
function scope()
    local var = "abc"

    require "child"
end

//child.lua
print(var)

这样,child.lua将打印一个nil值,因为parent.lua中的作用域不会将其本地功能公开给模块.我认为会这样,因为在此范围内和var声明之后声明了require指令.我的愿望是将孩子的所有行完全注入父母.只是导出子脚本以提高可读性.我如何通过本地范围? loadfile()不起作用,也没有dofile().函数环境fenv不包含本地值. debug.setlocal()似乎无法创建新变量(也需要子进程中的接收器).除了重新编译脚本之外的任何方法?

解决方法

你可以付出一点努力.如果子项中的变量是实数上升值,则可以将它们“链接”到范围函数中的值.如果它们是全局变量(这里似乎就是这种情况),您可以使用setfenv将它们映射到环境,并使用本地变量中的值填充该环境.

下面将按照您的预期打印abc(您可以将loadstring更改为loadfile,效果相同):

function vars(f)
  local func = debug.getinfo(f,"f").func
  local i = 1
  local vars = {}
  while true do
    local name,value = debug.getlocal(f,i)
    if not name then break end
    if string.sub(name,1,1) ~= '(' then vars[name] = value end
    i = i + 1
  end
  i = 1
  while func do -- check for func as it may be nil for tail calls
    local name,value = debug.getupvalue(func,i)
    if not name then break end
    vars[name] = value
    i = i + 1
  end
  return vars
end

function parent()
  local var = "abc"

  local child = loadstring("print(var)")

  local env = vars(2) -- grab all local/upvalues for the current function
  -- use these values to populate new environment; map to _G for everything else
  setmetatable(env,{__index = _G})
  setfenv(child,env)

  child()
end

parent()

这完全适用于Lua 5.1,但在Lua 5.2中也是如此.

(编辑:李大同)

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

    推荐文章
      热点阅读