我正在尝试使用 Python 的 __new__
以便在实例化类时返回与实际对象实例不同的东西(这是否聪明是一个不同的讨论)。下面是一个最小的示例,其中我从 __new__
返回了两个类实例的列表,而不是实际的类实例。
from copy import deepcopy
class TestClass:
def __new__(self, param=None):
self.__init__(self, param=param)
return [deepcopy(self), deepcopy(self)]
def __init__(self, param=None):
self.param = param
if __name__ == '__main__':
a = TestClass(param=1)
b = TestClass(param=2)
print(a[0].param) # prints 2!
但是,我似乎无法使用此方法创建实际的对象实例,如最小示例所示。 print
语句应该打印 1,但打印了 2,这意味着传递给 TestClass
的第二次调用的参数会覆盖第一次调用的参数。我的猜测是 a
和 b
是对同一个 static 类 TestClass 的引用,我的 deepcopy 也没有帮助,因为它没有对静态类有意义。
我该如何调整 TestClass
的 __new__
和 __init__
以便我实际上正在创建新实例(即打印语句应该打印 1,而不是 2)?
( python 3.5)
编辑/小澄清:我实际上不希望 TestClass 是静态的(如果这是正确的行话的话),但我的非功能性实现似乎产生了类似于静态类的东西。
解决方案
感谢 Kay,以下代码有效:
class TestClass(object):
def __new__(cls, param):
instance1 = object.__new__(cls)
instance1.__init__(param)
instance2 = object.__new__(cls)
instance2.__init__(param)
return instance1, instance2
def __init__(self, param):
self.param = param
最佳答案
你是在调用第一个参数给__new__
self
,但它实际上是类,通常称为cls
。所以你是在写给类,而不是实例。
要实际获得两个实例,请使用:
class X(object):
def __new__(cls, param):
self1 = object.__new__(cls)
self1.__init__(param)
self2 = object.__new__(cls)
self2.__init__(param)
return self1, self2
您不能使用 deepcopy,因为它会调用 X.__new__()
(没有 param
参数),这会导致循环。
关于python - 无法通过覆盖 __new__ 创建新的对象实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34054686/