我只是想简化我的一个类,并以与flyweight设计模式相同的样式介绍了一些功能。
但是,对于为什么__init__总是调用after ,我有点困惑__new__。我没想到这一点。谁能告诉我为什么会这样,否则我如何实现此功能?(除了将实现放入__new__hack之外)。
__init__
__new__
这是一个例子:
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()
输出:
NEW INIT EXISTS INIT EXISTS INIT
为什么?
使用 __new__ 时,你需要控制一个新实例的创建。 使用 __init__ 时,你需要一个新的实例的控件初始化。 __new__ 是实例创建的第一步。首先调用它,它负责返回类的新实例。 相反, __init__ 不返回任何东西。创建实例后,它仅负责初始化实例。 通常, __new__ 除非您要继承不可变类型(如str,int,unicode或tuple),否则不必重写。
使用 __new__ 时,你需要控制一个新实例的创建。
使用 __init__ 时,你需要一个新的实例的控件初始化。
__new__ 是实例创建的第一步。首先调用它,它负责返回类的新实例。
相反, __init__ 不返回任何东西。创建实例后,它仅负责初始化实例。
通常, __new__ 除非您要继承不可变类型(如str,int,unicode或tuple),否则不必重写。
从2008年4月后:当使用__new__对比__init__?在mail.python.org上。
您应该考虑到您通常想通过工厂完成的工作,这是最好的方法。使用 __new__ 不是一个好的清洁解决方案,因此请考虑使用工厂。在这里,您有一个很好的工厂示例。