Python中super()的理解以及應用場景實例
一、前言
最近有粉絲向我咨詢super相關的問題,說網上搜索到的教程不夠通俗易懂,看瞭之後還是不太理解。所以在這裡基於我自己的理解來講解一下super。
二、什麼是super
1.super也是一個類,是的。他不是一個方法也不是一個內置的關鍵字。
class A: pass print(type(super(A)))
輸出結果
<class ‘super’>
直接通過查看super的源碼也可以看出它是一個類
另外,網上很多文章講解super就是用來調用父類方法的,這也是一個錯誤的觀點!
假如我們有下面這樣一個例子:
class A: def __init__(self): print("A") class B(A): def __init__(self): print("B") super().__init__() class C(A): def __init__(self): print("C") super().__init__() class D(B, C): def __init__(self): print("D") super().__init__() D()
如果按照“super就是用來調用父類的方法的”這樣的理解來看,那上述代碼的執行的過程應該為:
print(“D”)—【調用super會先後執行B和C】—先執行B:print(“B”)—【調用super執行A】—print(“A”)—【調用super會先後執行B和C】—後執行C:print(“C”)—【調用super執行A】—print(“A”)
執行結果理論應該為:D B A C A
但實際情況卻不是這樣的!
實際執行結果
D
B
C
A
所以說“super就是用來調用父類的方法的”這個說法是錯誤的!
實際上super的調用是遵循Python的【MRO(方法解析順序)】來執行的,在Python3中,MRO是基於C3算法來實現的。
關於MRO和C3算法的講解可以參考這篇文章http://kaiyuan.me/2016/04/27/C3_linearization/
三、super的常用使用場景
1.假如我們繼承的多個父類有同名的方法,可以使用super來指定使用哪個父類的方法
class A: def test(self): print('A') class B: def test(self): print('B') class C(A, B): def __init__(self): super().test() # 調用A類中的test方法 super(C, self).test() # 調用A類中的test方法 super(A, self).test() # 調用B類中的test方法 C()
輸出結果
A
A
B
2.當我們在子類中使用父類的一個方法並且想對其做一定擴展又不想完全重寫,那麼使用super()就可以實現方法的增量修改:
舉一個例子,如果我們想把list中的append的方法改為中文添加應該怎麼做呢?
並且python中list調用append方法是沒有返回值的,我們想在添加元素操作成功後加一個返回值返回成功又該如何操作呢?
首先看通過調用原來的list的執行結果
a=list() res=a.append(1) print(res)
輸出結果
None
可以看到調用append方法後返回的值為None
現在我們通過super進行重寫,讓其具有返回值並可以直接通過中文來調用append:
class 列表(list): def 添加(self, *args, **kwargs): super().append(*args, **kwargs) return "添加成功" x = 列表() res = x.添加(1) print(res) print(x)
輸出結果
添加成功
[1]
super實際上還是很常用的,比如在restfremework中,需要重寫其響應結果的Response信息的時候,除瞭通過django的中間件實現,也可以使用super重寫其dispatch來實現。
總結
到此這篇關於Python中super()的理解以及應用場景的文章就介紹到這瞭,更多相關Python中super()應用場景內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Python編程super應用場景及示例解析
- python語法學習之super(),繼承與派生
- python中super()函數的理解與基本使用
- Python基礎之元編程知識總結
- C3 線性化算法與 MRO之Python中的多繼承