Python中MRO
生活随笔
收集整理的這篇文章主要介紹了
Python中MRO
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
MRO(方法解析順序)
當有多重繼承時,基于“從左到右,深度優先原則”:
class CommonBase():def Method(self):print('CommonBase')class Base1(CommonBase):passclass Base2(CommonBase):def Method(self):print('Base2')class MyClass(Base1,Base2):passMyClass().Method()# 執行結果:CommonBase當然如上算法時在python2中舊式類中(不繼承object)存在這樣的算法,當然在python3中定義類的時候已經顯示的繼承了object(不管你是否寫都默認地繼承了object)。當然也提供了一個新的MRO算法,在python3中運行如上代碼結果為:Base2
?
python super()調用多重繼承函數問題
https://blog.csdn.net/dl_chenbo/article/details/80602113
如上博文也闡明了關于多重繼承MRO問題,初次接觸肯定有違你的初衷。 明白MRO的算法之后,還要考慮一個問題就是不同種類的參數問題:
class CommonBase:def __init__(self):print('CommonBase')super().__init__()class Base1(CommonBase):def __init__(self):print('Base1')super().__init__()class Base2(CommonBase):def __init__(self,arg):print('Base2')super().__init__()class MyClass(Base1,Base2):def __init__(self,arg):print('MyClass')super().__init__(arg)MyClass(10)# 報錯如下:Traceback (most recent call last):File "E:/QMYG.BLOG/awesome-py3-webapp/test2.py", line 47, in <module>MyClass(10)File "E:/QMYG.BLOG/awesome-py3-webapp/test2.py", line 45, in __init__super().__init__(arg) TypeError: __init__() takes 1 positional argument but 2 were given解決如上問題,可以使用arg,*kw接收參數,但是這種設計方式不推薦,任何參數都可以傳入使得代碼比較脆弱。
最佳實踐
- 應該避免多重繼承
- super的使用必須一致
- 顯示地繼承object
- 調用父類時必須查看類的層次結構,通過mro
python私有屬性
使用雙下劃線為前綴,解析器會把該屬性重命名,使用組合名稱依然可以訪問該屬性。真正定義私有屬性的時候約定使用 _ 前綴,雖然同樣可以訪問,但不會調用任何名稱修飾的算法。
轉載于:https://www.cnblogs.com/tianboblog/p/9690763.html
總結
以上是生活随笔為你收集整理的Python中MRO的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 030 Substring with C
- 下一篇: Collections和Collecti