Python編程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其它相關文章!

推薦閱讀: