這篇文章帶給大家的內容是關於Python 中的super函數如何實現繼承?有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
Py 2.x 和 Py 3.x 中有一個很大的區別就是類,無論是類的定義還是類的繼承。 Py 3.x 中類別的繼承可以直接使用 super() 關鍵字來取代原來的 super(Class, self)。
那麼 super() 到底是依據什麼來繼承的呢?今天就來分析下。
super()函數根據傳進去的兩個參數具體作用如下:
透過第一參數傳進去的類別名稱來決定目前在MRO中的哪個位置。 MRO(Method Resolution Order);
透過第二個參數傳進去的self,確定目前的MRO清單。
def super(cls, inst): mro = inst.__class__.mro() #确定当前MRO列表 return mro[mro.index(cls) + 1] #返回下一个类
如下程式碼:
class A(object): def name(self): print('name is xiaoming') #super(A,self).name() class B(object): def name(self): print('name is cat') class C(A,B): def name(self): print('name is wang') super(C,self).name()if __name__ == '__main__': c = C() print(c.__class__.__mro__) c.name()
執行上述程式碼輸出:當執行C類別下的super()函數時,實際上呼叫了A類別下的name函數。 A中註解掉了super()函數,所以並沒有向後繼續執行。並且列印出了當前MRO列表順序為C,A,B,object.
(<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>)name is wangname is xiaoming
當我們把A類中的註解去掉後,執行程式碼輸出:可以看到,當A執行後繼續執行了B中的name()函數。如果B中仍有super函數則會繼續往上去尋找object中是否有name()函數。
(<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>)name is wangname is xiaomingname is cat
以上是Python中的super函數如何實作繼承?的詳細內容。更多資訊請關注PHP中文網其他相關文章!