如何将更改变量作为表的元素,如此。
local table = {}
local var = 10
现在我想将此变量作为table
的元素插入。
像这样:
table[1] = var
我需要的是,每当我调用此table[1]
时,即使变量发生变化,它也会调用该变量的实际值,如下所示:
print(table[1]) -> prints 10
var = var + 5
print(table[1]) -> prints 15
这有可能以某种方式吗?
编辑: 我想要完成的是:我希望在表中有一个元素,说明应该显示哪个变量。例如:
local var1 = 10
local var2 = 20
现在,如果我有一个表格,其元素就是这些变量的字符串,如下所示:
local table = {"var1", "var2"}
现在,如果我print(table[1])
,它当然会打印出" var1",但是我有什么方法可以将string
表的这个元素转换为当我真正需要那个变量时调用变量。你可能会问为什么我不打电话给var1
,但我有理由可以解释,但这会很长。让我们说我只需要这样。此外,var1
/ var2
可以更改。
答案 0 :(得分:4)
你有几个选择。
1)字段函数作为var的闭包:直截了当但需要更改使用方式
local t = {}
local var = 10
t.varf = function() return var end -- varf could be named var but that might be confusing
var = var + 5
print(t.varf()) -- call it to get the value
2)__ index metamethod避免显式函数调用语法
local t = {}
local var = 10
setmetatable(t, {
__index = function(_, k)
if k=="var" then return var else return nil
end})
var = var + 5
print(t.var) -- t does not contain a field with key "var" so __index is called
(__ index函数也是var的闭包。) 如果您想通过t修改var,请查看__newindex元方法。
两种方法都使用闭包。闭包是一个函数,它引用其参数和主体之外的非全局变量。
答案 1 :(得分:2)
Lua中的数字在分配时由 copy 共享。 table[1]
和var
都会收到他们自己的,10
的独立副本。
如果您想共享数字,则需要将它们封装在自己的表中。
local table = {}
local var = { value = 10 }
table[1] = var
print(table[1].value) -- prints 10
var.value = var.value + 5
print(table[1].value) -- prints 15
您还可以考虑在数字上创建某种抽象。一个简单的例子。但是,您需要确保您的操作定义明确。
local number = {}
number.__index = number
local function Number (value)
return setmetatable({ value = value }, number)
end
function number.__add (a, b)
if type(b) == 'number' then
return Number(a.value + b)
elseif getmetatable(b) == number then
return Number(a.value + b.value)
end
error("one of `number, Number' expected")
end
function number:add (n)
if type(n) == 'number' then
self.value = self.value + n
elseif getmetatable(n) == number then
self.value = self.value + n.value
else
error("one of `number, Number' expected")
end
return self.value
end
function number.__tostring (v)
return v.value .. ''
end
local foo = {}
local bar = Number(10)
foo[1] = bar
print(foo[1]) -- 10
bar:add(5)
print(foo[1]) -- 15
print(bar + 25) -- 40