Python中__new__和__init__的區別與聯系
__new__ 和 __init__ 的區別主要表現在:
__new__ 負責對象的創建而 __init__ 負責對象的初始化。
__new__:創建對象時調用,會返回當前對象的一個實例
__init__:創建完對象後調用,對當前對象的一些實例初始化,無返回值
1. 在類中,如果__new__和__init__同時存在,會優先調用__new__
class ClsTest(object): def __init__(self): print("init") def __new__(cls,*args, **kwargs): print("new")ClsTest()
輸出:
new
2. 如果__new__返回一個對象的實例,會隱式調用__init__
代碼實例:
class ClsTest(object): def __init__(self): print ("init") def __new__(cls,*args, **kwargs): print ("new %s"%cls) return object.__new__(cls, *args, **kwargs)ClsTest()
輸出:
new <class '__main__.ClsTest'>init
3. __new__方法會返回所構造的對象,__init__則不會。__init__無返回值。
class ClsTest(object): def __init__(cls): cls.x = 2 print ("init") return clsClsTest()
輸出:
initTraceback (most recent call last): File "<stdin>", line 1, in <module>TypeError: __init__() should return None, not 'ClsTest'
4. 若__new__沒有正確返回當前類cls的實例,那__init__是不會被調用的,即使是父類的實例也不行
class ClsTest1(object): passclass ClsTest2(ClsTest1): def __init__(self): print ("init") def __new__(cls,*args, **kwargs): print ("new %s"%cls) return object.__new__(ClsTest1, *args, **kwargs)b=ClsTest2()print (type(b))
輸出:
new <class ‘__main__.ClsTest2’>
<class ‘__main__.ClsTest1’>
知識點:
1. 繼承自object的新式類才有__new__
2. __new__至少要有一個參數cls,代表要實例化的類,此參數在實例化時由Python解釋器自動提供,__new__必須要有返回值,返回實例化出來的實例,可以return父類__new__出來的實例,或者直接是object的__new__出來的實例
3. __init__有一個參數self,就是這個__new__返回的實例,__init__在__new__的基礎上可以完成一些其它初始化的動作,__init__不需要返回值
4. 如果__new__返回一個對象的實例,會隱式調用__init__
更多關於Python中__new__和__init__的區別與聯系的介紹請查看下面的相關鏈接
推薦閱讀:
- python 特殊屬性及方法詳細解析
- python中super()函數的理解與基本使用
- 十一個案例帶你吃透Python函數參數
- for循環在Python中的工作原理詳細
- Python 變量教程之打包和解包參數