1.__new__(cls, *args, **kwargs) 創建對象時調用,返回當前對象的一個實例;注意:這里的第一個參數是cls即class本身
2.__init__(self, *args, **kwargs) 創建完對象后調用,對當前對象的實例的一些初始化,無返回值,即在調用__new__之后,根據返回的實例初始化;注意,這里的第一個參數是self即對象本身【注意和new的區別】
3.__call__(self, *args, **kwargs) 如果類實現了這個方法,相當于把這個類型的對象當作函數來使用,相當于 重載了括號運算符
看具體的例子:
代碼如下:
class O(object):
def __init__(self, *args, **kwargs):
print "init"
super(O, self).__init__(*args, **kwargs)
def __new__(cls, *args, **kwargs):
print "new", cls
return super(O, cls).__new__(cls, *args, **kwargs)
def __call__(self, *args, **kwargs):
print "call"
oo = O()
print "________"
oo()
打印出來的是:
代碼如下:
new
init
________
call
比如:Python Singleton(單例模式)實現,那我們是不是只是重載一些__new__方法就可以了
代碼如下:
class Singleton1(object):
""" 重載new方法"""
def __new__(cls, *args, **kwargs):
if not "_instance" in vars(cls):
cls._instance = super(Singleton1, cls).__new__(cls, *args, **kwargs)
return cls._instance
可不可以重載__init__方法呢?明顯不可以,因為__init__之前調用了__new__方法,這時候已經生成了一個對象了,沒辦法實現單例模式
新聞熱點
疑難解答