仅针对自己
__index的理解
__index是:当我们访问一个表中的元素不存在时,则会触发去寻找__index元方法,如果不存在,则返回nil,如果存在,则返回结果
1 Window = {} 2 3 Window.prototype = {x = 0,y = 0,wIDth = 100,height = 100,} 4 Window.mt = {} 5 function Window.new(o) 6 setMetatable(o,Window.mt) 7 return o 8 end 9 Window.mt.__index = function (t,key)10 -- body11 return 100012 end13 w = Window.new{x = 10,y = 20}14 print(w.wangbin)
打印结果是:1000。这里可以看出,我们在new的时候,w这个表里其实没有wangbin这个元素的,我们重写了元表中的__index,使其返回1000,意思是:如果你要寻找的元素,该表中没有,那么默认返回1000。
备注:__index也可以是一个表,我们这里也可以写__index = {wangbin = 1000},打印的值仍然可以是1000。
__newindex:当给你的表中不存在的值进行赋值时,lua解释器则会寻找__newindex元方法,发现存在该方法,则执行该方法进行赋值,注意,是使用rawset来进行赋值
1 Window.mt = {} 2 function Window.new(o) 3 setMetatable(o,Window.mt) 4 return o 5 end 6 Window.mt.__index = function (t,key) 7 return 1000 8 end 9 Window.mt.__newindex = function (table,key,value)10 if key == "wangbin" then11 rawset(table,"wangbin","yes,i am")12 end13 end14 w = Window.new{x = 10,y = 20}15 w.wangbin = "55"16 print(w.wangbin)
这里的打印结果是:yes,i am。w这个表里本来没有wangbin这个元素的,我们重写了元表中__newindex,并在__newindex方法中重新进行赋值 *** 作,然后,我们对这个本不存在的原色w.wangbin进行赋值时,执行__newindex方法的赋值 *** 作,最后,打印结果便是:yes,i am
rawget是为了绕过__index而出现的,直接点,就是让__index方法的重写无效。
1 Window = {} 2 3 Window.prototype = {x = 0,key)10 return 100011 end12 Window.mt.__newindex = function (table,value)13 if key == "wangbin" then14 rawset(table,i am")15 end16 end17 w = Window.new{x = 10,y = 20}18 print(rawget(w,w.wangbin))
打印结果是:nil。这里的元表中__index函数就不再起作用了。
1 Window = {} 2 Window.prototype = {x = 0,} 3 Window.mt = {} 4 function Window.new(o) 5 setMetatable(o,Window.mt) 6 return o 7 end 8 Window.mt.__index = function (t,key) 9 return 100010 end11 Window.mt.__newindex = function (table,value)12 table.key = "yes,i am"13 end14 w = Window.new{x = 10,y = 20}15 w.wangbin = "55"
我们的程序就stack overflow了。可见,程序陷入了死循环。因为w.wangbin这个元素本来就不存在表中,然后这里不断执行进入__newindex,陷入了死循环。
总结以上是内存溢出为你收集整理的Lua易忘点全部内容,希望文章能够帮你解决Lua易忘点所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)