在Lua中,每个“对象”是否都必须拥有自己方法的副本?

我有一个非常简单的类:

Point = {}
function Point:new(x,y)
   local self = {}
       self.x = x
       self.y = y
   --------------------
   function self.set(x,y)
       self.x = x
       self.y = y
   end
   function self.get()
       return {self.x,self.y}
   end
   --------------------
   return self
end

每个实例都包含所有方法。

这不是一种巨大的内存浪费吗?

如何存储实例的数据,但只有一个副本的方法?

点赞
用户3979429
用户3979429

你的解决方案是使用 metatables。通过设置 __index 字段,可以轻松地将 nil 值 “重新路由” 到 Point 表本身。因此,通过将方法存储在 Point 中,您不会占用太多内存!

Point = {}
function Point.set(self, x,y)
    self.x = x
    self.y = y
end
function Point.get(self)
    return {self.x,self.y}
end

function Point.new(self, x,y)
   local point = setmetatable({},{__index = Point})
       point.x = x
       point.y = y
   return point
end

print(table.unpack(Point:new(1,2):get()))
2015-11-22 15:11:50