关于_ENV(lua5.2 or later)

时间:2022-10-18 17:09:32
问:
 我调用了test模块中的del_env函数,但是main文件中的print并没有消失。
-- test.lua
local test = {}

function test.del_env ()
	_ENV = nil
end

return test

-- main.lua
local test = require "test"

test.del_env()

print "after delete _ENV"
答:
 _ENV itself is never a global name in a chunk. 
 _ENV 只是语法糖
 你的文件其实是一个函数 
-- test.lua
local _ENV
function test.del_env()
  _ENV = nil
end

return test
 你要看成是默认在前面加了一行 local _ENV然后在 load 的时候把当前的 _ENV 塞进去的
 print "after" 其实是_ENV.print "after"
 你要删外面环境的 _ENV, 应该用  debug.getupvalue 遍历外层函数, 找到 _ENV 置空 
 lua 5.2 已经没有所谓全局变量这种概念了
 所有东西都是函数
 你 load 一段代码其实就是一个函数/闭包
 如果你没有显式写 local _ENV 那么 parser 就帮你生成一个(如果你有全局变量语法
隐式的 _ENV 声明是 parser 帮你搞的
 它的值是 loader 塞进去的
 没有全局变量