Class 在Lua中,每个都做;“对象”;必须有自己的方法副本吗?

Class 在Lua中,每个都做;“对象”;必须有自己的方法副本吗?,class,oop,lua,prototypal-inheritance,Class,Oop,Lua,Prototypal Inheritance,我在这里有一个非常简单的课程: 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

我在这里有一个非常简单的课程:

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
每个实例中都有所有方法。
这是对内存的巨大浪费,不是吗?
如何存储实例的数据,但仅存储其方法的单个副本?

您的解决方案是元表。通过设置_索引字段,可以轻松地将nil值“重新路由”到点表本身。因此,通过将方法存储在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()))

您看到了吗?在Lua5.3中,函数定义的多次求值不再保证创建不同的函数值。这违背了您的假设,即存在方法的副本。(该示例也可以重写为跨实例显式重用方法。)但是,是的,如果没有
\uu index
,每个方法的每个实例中都必须有一个字段。上面提到的更改是在Lua 5.2(2011)中进行的。