我正在编写一个“C”用户数据数组结构。 作为setter和getter,我想要正常的数组访问(u [0] = 1 u [0]),如下所述: [c array share] [1] Share Array between lua and C。 为此,我需要将__index和__newindex设置为c。
中的set和get函数其他我也想要面向对象的访问,“就像你:mymethod()”。我的麻烦是,我现在需要将__index设置为metatable本身。
有没有办法实现两者?
答案 0 :(得分:4)
实现这一目标的众多可能方法之一:
local userdata = { _array = { "A", "B", "C" } }
local mt = { }
local methods = { }
function mt.__index(userdata, k)
if methods[k] then
return methods[k]
else
return rawget(userdata, "_array")[k]
end
end
function mt.__newindex(userdata, k, v)
if methods[k] then
error "can't assign to method!"
else
rawget(userdata, "_array")[k] = v
end
end
function methods.count(userdata)
return #rawget(userdata, "_array")
end
setmetatable(userdata, mt)
userdata[3] = "Z"
print(userdata[1])
print(userdata[2])
print(userdata[3])
print(userdata:count())
userdata.count = 0
编辑:正如lhf在他的评论中指出的那样,使用metatable完全没有危险,因为c-methods应该始终检查他们操作的自我。