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__的區別與聯系的介紹請查看下面的相關鏈接

推薦閱讀: