元表是一个表,有助于改变它连接到一个密钥集和相关的元方法的帮助下表的行为。这些元方法是强大的lua功能,如:
有迹象表明,在处理metatables其中包括使用了两种重要的方法,
让我们先来看看如何设置一个表作为另一个元表。它如下所示。
mytable = {} mymetatable = {} setmetatable(mytable,mymetatable)
上面的代码可以在一个单一的行被表示为如下所示。
mytable = setmetatable({},{})
__index
元表的查找元表时,它不是在表中提供一个简单的例子如下所示。
mytable = setmetatable({key1 = "value1"}, { __index = function(mytable, key) if key == "key2" then return "metatablevalue" else return mytable[key] end end })print(mytable.key1,mytable.key2)
当我们运行上面的程序,会得到下面的输出。
value1 metatablevalue
让解释发生了什么事,在上面的例子中的步骤,
我们可以有上述程序的简化版本,如下所示。
mytable = setmetatable({key1 = "value1"}, { __index = { key2 = "metatablevalue" } }) print(mytable.key1,mytable.key2)
__newindex
当我们增加__newindex到元表中,如果键是没有在表中可用的,新的键的行为将被中继的方法来定义。一个简单的示例,其中元表的索引时,索引不是在主表可设定如下。
mymetatable = {} mytable = setmetatable({key1 = "value1"}, { __newindex = mymetatable })print(mytable.key1)
mytable.newkey = "new value 2" print(mytable.newkey,mymetatable.newkey)
mytable.key1 = "new value 1" print(mytable.key1,mymetatable.newkey1)
当运行上面的程序,会得到如下的输出。
value1 nil new value 2 new value 1 nil
可以在上面的程序看,如果一个关键存在于主表,它只是更新它。当一个键不可用在maintable,它添加了关键metatable。
该更新用 rawset 函数相同的表的另一个例子如下所示。
mytable = setmetatable({key1 = "value1"}, { __newindex = function(mytable, key, value) rawset(mytable, key, "\""..value.."\"")end })
mytable.key1 = "new value" mytable.key2 = 4
print(mytable.key1,mytable.key2)
当我们运行上面的程序,会得到下面的输出。
new value "4"
rawset 设定值,而不使用元表 __newindex。同样有rawget,获取的值,而无需使用__index。
表加入操作符的行为
一个简单的例子结合使用+运算符的两个表如下所示。
mytable = setmetatable({ 1, 2, 3 }, { __add = function(mytable, newtable) for i = 1, table.maxn(newtable) do table.insert(mytable, table.maxn(mytable)+1,newtable[i]) end return mytable end })secondtable = {4,5,6}
mytable = mytable + secondtable for k,v in ipairs(mytable) do print(k,v) end
当我们运行上面的程序,会得到下面的输出
1 1 2 2 3 3 4 4 5 5 6 6
该__add密钥包含在元表中添加操作符+行为。表的键和相应的操作符如下所示。
__call
完成方法调用的添加行为,使用__call声明。一个简单的例子,返回值的主表的总和与传递表。
mytable = setmetatable({10}, { __call = function(mytable, newtable) sum = 0 for i = 1, table.maxn(mytable) do sum = sum + mytable[i] end for i = 1, table.maxn(newtable) do sum = sum + newtable[i] end return sum end }) newtable = {10,20,30} print(mytable(newtable))
当我们运行上面的程序,会得到下面的输出。
70__tostring
更改打印语句的行为,可以用__toString元方法。一个简单的例子如下所示。
mytable = setmetatable({ 10, 20, 30 }, { __tostring = function(mytable) sum = 0 for k, v in pairs(mytable) do sum = sum + v end return "The sum of values in the table is " .. sum end }) print(mytable)
当我们运行上面的程序,会得到下面的输出。
The sum of values in the table is 60
如果知道元数据表的功能完全,真的可以执行很多操作,这将是不使用它非常复杂。所以尽量让工作使用metatables在元表提供不同的选择作为样本的解释,也可以创建自己的样品。
本文向大家介绍Lua中的元方法__newindex详解,包括了Lua中的元方法__newindex详解的使用技巧和注意事项,需要的朋友参考一下 好吧,我写文章的进度已经赶不上看书的进度了,简单的几段文字就够我唠叨一篇文章了。 今天继续来说说元方法,与__index有点相似的__newindex元方法。 1.查询与更新 上一篇文章我们介绍了__index元方法,总结来说,__index元方法是用于处
本文向大家介绍Lua中的metatable详解,包括了Lua中的metatable详解的使用技巧和注意事项,需要的朋友参考一下 Lua 中 metatable 是一个普通的 table,但其主要有以下几个功能: 1.定义算术操作符和关系操作符的行为 2.为 Lua 函数库提供支持 3.控制对 table 的访问 Metatables 定义操作符行为 Metatable 能够被用于定义算术操作符和关
本文向大家介绍Lua中强大的元方法__index详解,包括了Lua中强大的元方法__index详解的使用技巧和注意事项,需要的朋友参考一下 今天要来介绍比较好玩的内容——__index元方法 1.我是备胎,记得回头看看 咳咳,相信每一位女生都拥有或者不知不觉中拥有了一些备胎,啊,当然,又或许是成为过别人的备胎。 没有备胎的人,就不是完整的人生。(小若:停!) 我们来想象一下,如果对一个tabl
本文向大家介绍Lua中的__index方法详解,包括了Lua中的__index方法详解的使用技巧和注意事项,需要的朋友参考一下 当我们访问一个表的不存在的域,返回结果为nil,这是正确的,但并不一定正确。实际上,这种访问触发lua解释器去查找__index metamethod:如果不存在,返回结果为nil;如果存在则由__index metamethod返回结果。 这个例子的原型是一种继承。假设
主要内容:__index 元方法,实例,__newindex 元方法,实例,实例,为表添加操作符,实例,__call 元方法,实例,__tostring 元方法,实例在 Lua table 中我们可以访问对应的 key 来得到 value 值,但是却无法对两个 table 进行操作(比如相加)。 因此 Lua 提供了元表(Metatable),允许我们改变 table 的行为,每个行为关联了对应的元方法。 例如,使用元表我们可以定义 Lua 如何计算两个 table 的相加操作 a+b。 当 L
在 Lua table 中我们可以访问对应的key来得到value值,但是却无法对两个 table 进行操作。 因此 Lua 提供了元表(Metatable),允许我们改变table的行为,每个行为关联了对应的元方法。 例如,使用元表我们可以定义Lua如何计算两个table的相加操作a+b。 当Lua试图对两个表进行相加时,先检查两者之一是否有元表,之后检查是否有一个叫"__add"的字段,若找到