更改表中的变量

时间:2016-08-10 21:55:10

标签: lua corona

如何将更改变量作为表的元素,如此。

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 可以更改

2 个答案:

答案 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