Lua 中的继承

我正在尝试创建一个简单的 API,以简化创建类和子类的过程。

function newClass(index,...)
  local new_class = {}

  setmetatable(new_class,{__index = index})

  local optionalArgs = {...}
  if optionalArgs[1] ~= nil then
      setmetatable(new_class,optionalArgs[1])
  end

  return new_class

end

--TESTINGCODE
exampleSuper = newClass({name="Super",id=1,getName = function() print("Super") end,})
exampleSuper.getName()
exampleSub = newClass({name="Sub",},exampleSuper)
print(exampleSub.id)

问题是,即使我创建了一个名为exampleSuper的新超类,其字段也没有被赋给exampleSub类。我应该如何更改代码以允许我的函数定义一个子类?

点赞
用户3735873
用户3735873
函数 newClass(new_obj,old_obj)
  old_obj = old_obj or {}               --使用传入的对象(如果有)
  new_obj = new_obj or {}
  assert(type(old_obj) == 'table','Object/Class is not a table')  --断言:对象/类不是一个表格
  assert(type(new_obj) == 'table','Object/Class is not a table')  --断言:对象/类不是一个表格
  old_obj.__index = old_obj             --将__index存储在父对象中(优化)
  return setmetatable(new_obj,old_obj)  --创建一个'new_obj'继承'old_obj'
end
2015-04-20 22:09:25
用户1442917
用户1442917

这个问题在《Lua编程》的面向对象编程章节中得到了很好的回答,特别是在继承部分。

在你的特殊情况下,当 optionalArgs[1] ~= nil 检查为真时,你没有在元表中设置 __index,因为你覆盖了之前的赋值。

2015-04-20 22:13:34
用户3574628
用户3574628

newClass 中,你第二次调用 setmetatable 语句将简单地覆盖第一句。下面的更短的函数会给你期望的结果:

function newClass(new_class, super)
  new_class = new_class or {}

  -- 这假设单一继承。多继承需要一个重载 __index 函数。
  if super then
    setmetatable(new_class,{__index = super})
  end

  return new_class

end
2015-04-22 04:56:01