Python編程super應用場景及示例解析
一、什么是super
1.super也是一個類,是的。他不是一個方法也不是一個內置的關鍵字。
class A: pass print(type(super(A)))
輸出結果
<class 'super'>
直接通過查看super的源碼也可以看出它是一個類

另外,網(wǎng)上很多文章講解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就是用來調用父類的方法的”這樣的理解來看,那上述代碼的執(zhí)行的過程應該為:
print("D")—【調用super會先后執(zhí)行B和C】—先執(zhí)行B:print("B")—【調用super執(zhí)行A】—
print("A")—【調用super會先后執(zhí)行B和C】—后執(zhí)行C:print("C")—【調用super執(zhí)行A】—
print("A")
執(zhí)行結果理論應該為:D B A C A
但實際情況卻不是這樣的!
實際執(zhí)行結果
D
B
C
A
所以說“super就是用來調用父類的方法的”這個說法是錯誤的!
實際上super的調用是遵循Python的【MRO(方法解析順序)】來執(zhí)行的,在Python3中,MRO是基于C3算法來實現(xiàn)的。
關于MRO和C3算法的講解可以參考這篇文章https://www.jb51.net/article/224606.htm
三、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()就可以實現(xiàn)方法的增量修改:
舉一個例子,如果我們想把list中的append的方法改為中文添加應該怎么做呢?
并且python中l(wèi)ist調用append方法是沒有返回值的,我們想在添加元素操作成功后加一個返回值返回成功又該如何操作呢?
首先看通過調用原來的list的執(zhí)行結果
a=list() res=a.append(1) print(res)
輸出結果
None
可以看到調用append方法后返回的值為None
現(xiàn)在我們通過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的中間件實現(xiàn),也可以使用super重寫其dispatch來實現(xiàn)。
以上就是Python編程super應用場景及示例解析的詳細內容,更多關于Python編程super應用的資料請關注本站其它相關文章!
版權聲明:本站文章來源標注為YINGSOO的內容版權均為本站所有,歡迎引用、轉載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內容涉嫌侵權,請聯(lián)系alex-e#qq.com處理。
關注官方微信