元表Metatable
Lua提供了元表,允许我们改变table的行为,每个行为关联了对应的元方法。
例如,使用元表我们可以定义Lua如何计算两个table的相加操作a+b。
当Lua试图对两个表进行相加时,先检查两者之一是否有元表,之后检查是否有一个叫"__add"的字段,若找到,则调用对应的值。"__add"等即时字段,其对应的值(往往是一个函数或是table)就是"元方法"。
__index元方法
Lua 查找一个表元素时的规则,其实就是如下 3 个步骤:
1.在表中查找,如果找到,返回该元素,找不到则继续
2.判断该表是否有元表,如果没有元表,返回 nil,有元表则继续。
3.判断元表有没有 __index 方法,如果 __index 方法为 nil,则返回 nil;如果 __index 方法是一个表,则重复 1、2、3;如果 __index 方法是一个函数,则返回该函数的返回值。
__tostring
tb3.__tostring = function(mytable)
local temp = "{"
for i = 1, #mytable do
if i ~= #mytable then
temp = temp .. mytable[i] .. ",";
else
temp = temp .. mytable[i];
end
end
temp = temp .."}";
return temp;
end
__newindex
__newindex 元方法用来对表更新,__index则用来对表访问 。
当你给表的一个缺少的索引赋值,解释器就会查找__newindex 元方法:如果存在则调用这个函数而不进行赋值操作。
如果没有__newindex,就会进行原始操作赋值。
tb1 = {}
tb2 = setmetatable({key1 = "value1"},tb1);
function tb1.__newindex(...)
for k, v in pairs(...) do
print(k);
print(v);
end
print("newindex");
end
tb2.key2 = "ss";
print(tb1.key2,tb2.key2);
用rawset更新表,newindex会传3个参数,一个声明的__newindex的表,一个缺少的key,和要赋值的value
function tb1.__newindex(mytable,key,value)
rawset(mytable,key," 这是值:"..value);
end
当原表的__newindex为一个表,将此原表设为原表的表在为不存在的值赋值时,将调用原表的__newindex,在__newindex中查找有没有要赋值的key
网友评论