Python多繼承之MRO演算法

來源:互聯網
上載者:User

標籤:img   port   inf   eth   一個   main   pytho   問題   object   

MRO即Method Resolution Order   方法解析順序,它的提出主要是為瞭解決Python中多繼承時,當父類存在同名函數時,二義性的問題

下面先看一個例子:

import inspectclass D:    passclass C(D):    passclass B(D):    passclass A(B, C):    passif __name__ == ‘__main__‘:    print(inspect.getmro(A))

B和C繼承D   A繼承B和C  這是一個簡單的多繼承,下面看Python3中的輸出結果:

(<class ‘__main__.A‘>, <class ‘__main__.B‘>, <class ‘__main__.C‘>, <class ‘__main__.D‘>, <class ‘object‘>)

執行結果是 A ->B ->C ->D

 

在Python3中,MRO演算法採用的是有向非循環圖的拓撲排序,這裡我們採用剪枝的方法來分析:

如所示:首先找入度為0的點 A,因為沒有類繼承A,剪去A左右兩邊,得到 A ->:

 

接下來再找下一個入度為0的點(剪枝後沒有類繼承B和C了),B和C的入度為0,根據先取最左原則,剪去B的枝,得到 A ->B ->:

 

再找到入度為0的點為C,則剪去C的枝得到 A ->B ->C ->

最後得到: A ->B ->C ->D的順序

 

 

接下來看Python2.7下的執行結果:

(<class __main__.A at 0x7f81a17ca1f0>, <class __main__.B at 0x7f81a17ca188>, <class __main__.D at 0x7f81a17ca0b8>, <class __main__.C at 0x7f81a17ca120>)

可以看到執行結果是 A ->B ->D ->C

這裡和python3執行結果不同是因為 Python2.7的MRO演算法採用的是深度優先搜尋(子節點順序:從左至右),所以是 A ->B ->D ->C

 

Python多繼承之MRO演算法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.