lua面向对象编程是基于元表metatable,元方法__index来实现的 通过元表的__index元方法,将一个table的__index元方法设置为另一个table,那么后者的方法就被前者继承
如果访问了lua表中不存在的元素时,就会触发lua的一套查找机制,也是凭借这个机制,才能够实现面向对象的 总结元表的查找步骤: 步骤1.在表中查找,如果找到,返回该元素,找不到则继续步骤2 步骤2.判断该表是否有元表,如果没有元表,返回nil,有元表则继续步骤3 步骤3.判断元表有没有__index方法,如果__index方法为nil,则返回nil;如果__index方法是一个表,则重复步骤1、2、3;如果__index方法是一个函数,则调用该函数,并返回该函数的返回值
- 元表像是一个备用查找表,假设表A的元表是B,那么在A中找不到的东西就会尝试在B中去找,设置元表的函数如下
- setmetatable(A, B),这样表B就被设置为A的元表,当A中查找不到某个变量时就会到B中进行查找
- 元方法__index是用来确定一个表在被作为元表时的查找方法
-- 设置新对象的metatable setmetatable(tempObj,Class)
父类:-- 设置metatable的元方法__index,指向表Class自己 Class.__index = Class -- 设置新对象的metatable, setmetatable(tempObj,Class) 子类:-- 设置元表为Class setmetatable(SubClass, Class) -- 设置metatable的元方法__index,指向表SubClass自己 SubClass.__index = SubClass
2、直接将基类的成员深拷贝给子类
:对外只有class函数,参数为基类的名称,返回一个派生类的对象数据。函数的作用是根据传入的基类,拿到对应的元表来初始化派生类对象的元表,这样在代码运行时,不需要动态向上查找,缺陷在于这样做在对象创建时会消耗更多的时间。
|
请发表评论