gpt4 book ai didi

python - 无法通过覆盖 __new__ 创建新的对象实例

转载 作者:太空宇宙 更新时间:2023-11-04 08:04:24 24 4
gpt4 key购买 nike

我正在尝试使用 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 的第二次调用的参数会覆盖第一次调用的参数。我的猜测是 ab 是对同一个 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com