class Singleton(type):
def __init__(self, *args, **kwargs):
print 'calling __init__ of Singleton class', self
print 'args: ', args
print 'kwargs: ', kwargs
super(Singleton, self).__init__(*args, **kwargs)
self.__instance = None
def __call__(self, *args, **kwargs):
print 'running __call__ of Singleton', self
print 'args: ', args
print 'kwargs: ', kwargs, '\n\n'
if self.__instance is None:
self.__instance = super(Singleton, self).__call__(*args, **kwargs)
return self.__instance
class A(object):
__metaclass__ = Singleton
def __init__(self,a):
print 'in __init__ of A: ', self
self.a = a
print 'self.a: ', self.a
a=A(10)
b=A(20)
我从 Ben 对Python 使用 __new__ 和 __init__的问题的回答中复制了这段代码?并稍作修改。但是,我不知道流量。尽管我从更高的层次上理解了这段代码的目的。但是,在内部它是如何工作的,我不太确定。
运行此代码时,我得到以下输出:-
calling __init__ of Singleton class <class '__main__.A'>
args: ('A', (<type 'object'>,), {'__module__': '__main__', '__metaclass__': <class '__main__.Singleton'>, '__init__': <function __init__ at 0x01F9F7B0>})
kwargs: {}
running __call__ of Singleton <class '__main__.A'>
args: (10,)
kwargs: {}
in __init__ of A: <__main__.A object at 0x01FA7A10>
self.a: 10
running __call__ of Singleton <class '__main__.A'>
args: (20,)
kwargs: {}
我无法理解args
andkwargs
是如何变得不同的__init__
。__call__
在使用元类时,这个链接(What is a metaclass in Python?)解释了如何使用__new__
元类和函数。但是,我不明白__call__
是如何使用的。
有人可以解释一下流程吗?我的意思是,调用 , 和谁调用它们的__new__
优先__call__
级__init__
?