码迷,mamicode.com
首页 > 其他好文 > 详细

对lua继承中self.__index = self的释疑

时间:2016-06-30 19:38:49      阅读:231      评论:0      收藏:0      [点我收藏+]

标签:

首先看看从lua表中查找一个键时的流程:

技术分享

-- 当从表t中查找键k时,lua处理如下:
-- 1.t中是否有k,有则直接返回值,否则第2步
-- 2.t是否有元表, 无则返回nil, 有则第3步
-- 3.t的元表是否有__index元方法, 无则返回nil, 有则查找__index指向的表或对应的方法

---注意两种写法
-- 写法1, 可以保持继承链
local class = {}

function class:new()
	self.__index = self
	return setmetatable( {}, self )
end

function class:say()
	print(111)
end

local o1 = class:new()
o1.say()

local o2 = o1:new()
o2.say()

--- 写法2, 只能继承1次, 第2次派生时没了__index元方法
local class = {}
class.__index = class

function class:new()
	return setmetatable( {}, self )
end

function class:say()
	print(111)
end

local o1 = class:new()
o1.say()

-- 第2次继承失败了, 因为o1并没有__index元方法
local o2 = o1:new()
o2.say()

技术分享  

对lua继承中self.__index = self的释疑

标签:

原文地址:http://www.cnblogs.com/tudas/p/how-to-understand-lua-oo-self__index.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!