您好,登錄后才能下訂單哦!
這篇文章主要介紹“python super()函數怎么使用”,在日常操作中,相信很多人在python super()函數怎么使用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”python super()函數怎么使用”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
Python是一門面向對象的語言,定義類時經常要用到繼承,在類的繼承中,子類繼承父類中已經封裝好的方法,不需要再次編寫,如果子類如果重新定義了父類的某一方法,那么該方法就會覆蓋父類的同名方法,但是有時我們希望子類保持父類方法的基礎上進行擴展,而不是直接覆蓋,就需要先調用父類的方法,然后再進行功能的擴展,這時就可以通過super來實現對父類方法的調用。
看下面一個例子:
class A: def func(self): print("A的func執行") class B(A): def func(self): super().func() print("B擴展的func執行") b = B() b.func()
# 輸出結果為:
# A的func執行
# B擴展的func執行
上面程序中,A是父類,B是A的子類,我們在A類中重定義了func()方法,在B類中重新定義了func()方法,在方法中通過super().func()又調用了父類的方法,所以執行結果才會有A類func()方法輸出。
如果經常看Python內置庫及第三方庫源碼的話,你會發現,super用的非常多的地方是在子類中調用父類的初始化__init__()方法,這種用法非常常見。
class A: def __init__(self, x): self.x = x class B(A): def __init__(self, x, y): super().__init__(x) self.y = y b = B(1, 2) print(b.x, b.y)
看到這,你會想到super就是用來獲取父類并用來調用父類方法的,這樣說對不對呢,其實是不對的,使用supper獲取的不是父類,而是MRO列表中的下一個類,所謂MRO列表即方法解析順序(Method Resolution Order)列表,它代表著類繼承的順序,我們可以使用以下幾種獲得某個類的MRO列表:
C.mro() C.__mro__ c.__class__.__mro__
MRO列表的順序確定經歷了很多次的變遷,最新的是通過C3線性化算法來實現的,感興趣的話可以自行了解一下,總的來說,一個類的MRO列表就是合并所有父類的MRO列表,并遵循以下三條原則:
子類永遠在父類前面
如果有多個父類,會根據它們在列表中的順序被檢查
如果對下一個類存在兩個合法的選擇,選擇第一個父類
下面來看一下下面這個例子:
class A(Base): def func(self): print("A的func執行") super().func() print("A的func執行完畢") class B(Base): def func(self): print("B的func執行") super().func() print("B的func執行完畢") class C(A, B): def func(self): print("C的func執行") super().func() print("C的func執行完畢") c = C() c.func() # 獲取MRO列表 print(c.__class__.__mro__)
執行結果如下:
上述程序中,Base是父類,A、B都繼承自Base,C繼承自 A、B,它們的繼承關系就是一個典型的菱形繼承,如下:
通過結果我們可以看出,super并不是獲取父類并用來調用父類的方法,而是根據MRO列表一次調用下一個類,使用c.__class__.__mro__可以獲取MRO列表,MRO列表的順序是C、A、B、Base、object。
super計算方法解析順序中的下一個類,可以接收兩個參數:
def super(cls, inst): mro = inst.__class__.mro() return mro[mro.index(cls) + 1]
到此,關于“python super()函數怎么使用”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。