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

标签 python

我正在尝试使用 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/

相关文章:

python - 我的基于 Django 的项目偶尔停止加载 View (Django 1.6)

python - 从整数中删除最后一位并在 python 中放入零

python - 如何复制在 Python 函数调用中不会更改的列表

python - 将帧合并为一个视频时如何避免系统死机

具有多个子句的 Python if 语句

Python-填充未使用的日期

python - 检查 csv 文件中的输入

python - 几个模型的聚合 - Django

c# - 为 .NET 开发人员学习 Python

python - Python中删除多列中的非中文元素