前言
本文主要介紹了關于Python實例化class的執行順序的相關內容,下面話不多說了,來一起看看詳細的介紹吧
Python里對類的實例化時有怎樣的順序
一般來說一個類里面有類變量和方法,比如我們定義一個名為A的類
class A(): bar = "my lover love me" def __init__(self, name): print('A的class' ,self.__class__, name)
我們在這個類里面定義了一個類變量bar和一個構造方法__init__,那么我們實例化A()時都發生了什么呢!看官不要急,聽我慢慢道來...
首先,python 調用內置的type類,沒有聽錯,就是我們平時用來測引用類型的那個type,然后type調用內置的元類mateClass,mateClass再調用__new__方法將類實例化,此時完成了第一步 然后,這個實例將會初始化自己的類變量,就是把自己從頭到尾掃視一遍, 之后,進入構造方法,并初始化自己的實例變量。注意:python中類變量和實例變量是不一樣的,
類變量:不用實例化也可以訪問。
實例變量:是動態創建的。必須實例化之后才可以訪問,因為之前是不存在的。
比如下面這個例子:不實例化訪問類變量
class A(): a = 2print(A.a)
輸出:
>>>2
說了這么多,上代碼??纯搭惱^承時怎么運行的:
class A(): def __init__(self, name): print('A的class' ,self.__class__, name) class B(A): def __init__(self, name): self._name = name A.__init__(self, name) print('B的class', self.__class__, name) print('this is B class') class C(B): def __init__(self, name): B.__init__(self, name) print('C的class') if __name__ == '__main__':c = C('lee')
輸出如下:
this is B class
A class <class '__main__.C'> lee
B class <class '__main__.C'> lee
C class
來現身說法,解釋一波
首先對class C()進行實例化,從頭到尾掃一遍,然后進入C()的構造,遇到了父類C()的構造方法B.__init__ 。 進入class B(),從頭到尾掃一遍,執行了print('this is B class')
語句然后進入B()的構造,遇到了父類B()的構造方法A.__init__。 進入class A(),從頭到尾掃一遍,然后進入A()的構造方法A.__init__。然后A.__init__執行完畢并彈出棧,class A()執行完畢并彈出棧。 回到class B(),從上次未執行完的地方print('B的class', self.__class__, name)
繼續執行。然后B.__init__執行完畢并彈出棧,class B()執行完畢并彈出棧。 回到class C(),從上次未執行完的地方print('C的class')
繼續執行。然后C.__init__執行完畢并彈出棧,class C()執行完畢并彈出棧。程序運行完畢。 由于是對class C()進行實例化,上面的self都是指class C()的實例而不是class A()的或者class B()的。因此self.__class__清一色的顯示
新聞熱點
疑難解答