Python-为什么总是在__new __()之后调用__init __()?
我只是想简化我的一个类,并以与flyweight设计模式相同的样式介绍了一些功能。
但是,对于为什么__init__
总是被称为after ,我有点困惑__new__
。我没想到这一点。谁能告诉我为什么会这样,否则我如何实现此功能?(除了将实现放到__new__hacky
中之外)。
这是一个例子:
class A(object): _dict = dict()
def __new__(cls):
if 'key' in A._dict:
print "EXISTS"
return A._dict['key']
else:
print "NEW"
return super(A, cls).__new__(cls)
def __init__(self):
print "INIT"
A._dict['key'] = self
print ""
a1 = A()
a2 = A()
a3 = A()
输出:
NEWINIT
EXISTS
INIT
EXISTS
INIT
为什么?
回答:
使用__new__
时,你需要控制一个新实例的创建。
使用 __init__
时,你需要一个新的实例的控件初始化。
__new__
是实例创建的第一步。首先调用它,它负责返回类的新实例。
相反, __init__
不返回任何东西。创建实例后,它仅负责初始化实例。
通常,除非你要__new
继承不可变类型(如str,int,unicode或tuple
),否则无需覆盖__`。
从2008年4月发布:何时使用__new__vs __init__
?在mail.python.org上。
你应该考虑到你通常想通过工厂来完成的工作,这是最好的方法。使用__new__
不是一个好的清洁解决方案,因此请考虑使用工厂。在这里,你有一个很好的工厂示例。
以上是 Python-为什么总是在__new __()之后调用__init __()? 的全部内容, 来源链接: utcz.com/qa/424209.html