Python中super()的理解以及應(yīng)用場(chǎng)景實(shí)例
一、
最近有粉絲向我咨詢(xún)super相關(guān)的問(wèn)題,說(shuō)網(wǎng)上搜索到的教程不夠通俗易懂,看了之后還是不太理解。所以在這里基于我自己的理解來(lái)講解一下super。
二、什么是super
1.super也是一個(gè)類(lèi),是的。他不是一個(gè)方法也不是一個(gè)內(nèi)置的關(guān)鍵字。
class A: pass print(type(super(A)))
輸出結(jié)果
<class 'super'>
直接通過(guò)查看super的源碼也可以看出它是一個(gè)類(lèi)

另外,網(wǎng)上很多文章講解super就是用來(lái)調(diào)用父類(lèi)方法的,這也是一個(gè)錯(cuò)誤的觀點(diǎn)!
假如我們有下面這樣一個(gè)例子:
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就是用來(lái)調(diào)用父類(lèi)的方法的”這樣的理解來(lái)看,那上述代碼的執(zhí)行的過(guò)程應(yīng)該為:
print("D")—【調(diào)用super會(huì)先后執(zhí)行B和C】—先執(zhí)行B:print("B")—【調(diào)用super執(zhí)行A】—print("A")—【調(diào)用super會(huì)先后執(zhí)行B和C】—后執(zhí)行C:print("C")—【調(diào)用super執(zhí)行A】—print("A")
執(zhí)行結(jié)果理論應(yīng)該為:D B A C A
但實(shí)際情況卻不是這樣的!
實(shí)際執(zhí)行結(jié)果
D
B
C
A
所以說(shuō)“super就是用來(lái)調(diào)用父類(lèi)的方法的”這個(gè)說(shuō)法是錯(cuò)誤的!
實(shí)際上super的調(diào)用是遵循Python的【MRO(方法解析順序)】來(lái)執(zhí)行的,在Python3中,MRO是基于C3算法來(lái)實(shí)現(xiàn)的。
關(guān)于MRO和C3算法的講解可以參考這篇文章http://kaiyuan.me/2016/04/27/C3_linearization/
三、super的常用使用場(chǎng)景
1.假如我們繼承的多個(gè)父類(lèi)有同名的方法,可以使用super來(lái)指定使用哪個(gè)父類(lèi)的方法
class A:
def test(self):
print('A')
class B:
def test(self):
print('B')
class C(A, B):
def __init__(self):
super().test() # 調(diào)用A類(lèi)中的test方法
super(C, self).test() # 調(diào)用A類(lèi)中的test方法
super(A, self).test() # 調(diào)用B類(lèi)中的test方法
C()
輸出結(jié)果
A
A
B
2.當(dāng)我們?cè)谧宇?lèi)中使用父類(lèi)的一個(gè)方法并且想對(duì)其做一定擴(kuò)展又不想完全重寫(xiě),那么使用super()就可以實(shí)現(xiàn)方法的增量修改:
舉一個(gè)例子,如果我們想把list中的append的方法改為中文添加應(yīng)該怎么做呢?
并且python中l(wèi)ist調(diào)用append方法是沒(méi)有返回值的,我們想在添加元素操作成功后加一個(gè)返回值返回成功又該如何操作呢?
首先看通過(guò)調(diào)用原來(lái)的list的執(zhí)行結(jié)果
a=list() res=a.append(1) print(res)
輸出結(jié)果
None
可以看到調(diào)用append方法后返回的值為None
現(xiàn)在我們通過(guò)super進(jìn)行重寫(xiě),讓其具有返回值并可以直接通過(guò)中文來(lái)調(diào)用append:
class 列表(list): def 添加(self, *args, **kwargs): super().append(*args, **kwargs) return "添加成功" x = 列表() res = x.添加(1) print(res) print(x)
輸出結(jié)果
添加成功
[1]
super實(shí)際上還是很常用的,比如在restfremework中,需要重寫(xiě)其響應(yīng)結(jié)果的Response信息的時(shí)候,除了通過(guò)django的中間件實(shí)現(xiàn),也可以使用super重寫(xiě)其dispatch來(lái)實(shí)現(xiàn)。
總結(jié)
到此這篇關(guān)于Python中super()的理解以及應(yīng)用場(chǎng)景的文章就介紹到這了,更多相關(guān)Python中super()應(yīng)用場(chǎng)景內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信