Python中內(nèi)置函數(shù)super()用法示例詳解
前言
在面向?qū)ο缶幊讨?,類常有繼承關(guān)系,子類需要復(fù)用或擴(kuò)展基類邏輯。Python 提供內(nèi)置函數(shù) super(),返回一個(gè)代理對象,用于按 MRO(方法解析順序) 調(diào)用當(dāng)前類之后的下一個(gè)類的方法。這樣可以避免硬編碼父類名,使代碼在多繼承下更健壯、可維護(hù)。
一、函數(shù)語法
super([type[, object-or-type]])
參數(shù):
- type:可選。通常為當(dāng)前類。
- object-or-type:可選。當(dāng)前實(shí)例(self)或當(dāng)前類(配合類方法/靜態(tài)方法顯式傳入)。
常見寫法:
??實(shí)例方法
super().method(...) # 等價(jià)于: super(CurrentClass, self).method(...)
??類方法
@classmethod
def m(cls, ...):
super().method(...)
# 等價(jià)于:
super(CurrentClass, cls).method(...)返回值:
一個(gè) super 代理對象,可用于調(diào)用 MRO 中“當(dāng)前類之后的下一個(gè)類” 的方法。
提示:
Python 3 支持零參 super()。單參形式很少需要,一般用零參或兩參。
二、基礎(chǔ)用法示例
1、基本繼承調(diào)用
class Parent:
def greet(self):
print("Hello from Parent")
class Child(Parent):
def greet(self):
super().greet() # 調(diào)用父類方法
print("Hello from Child")
c = Child()
c.greet()
# Hello from Parent
# Hello from Child2、構(gòu)造函數(shù)鏈
class A:
def __init__(self):
print("A init")
class B(A):
def __init__(self):
super().__init__() # 調(diào)用 A.__init__()
print("B init")
b = B()
# A init
# B init三、進(jìn)階技巧
1、多繼承與 MRO(方法解析順序)
class A:
def greet(self):
print("A")
class B(A):
def greet(self):
super().greet()
print("B")
class C(A):
def greet(self):
super().greet()
print("C")
class D(B, C):
def greet(self):
super().greet()
print("D")
d = D()
d.greet()
# A
# C
# B
# DMRO 順序:D → B → C → A → object。
super() 并非“父類調(diào)用”,而是沿 MRO 從當(dāng)前類的后繼繼續(xù)向上。
2、顯式兩參 super()
當(dāng)你不在方法定義的典型上下文(或需要手動(dòng)指明上下文)時(shí),可顯式傳入兩參:
class Base:
def who(self): print("Base.who")
class Sub(Base):
def who(self):
print("Sub.who → call super:")
return super(Sub, self).who()
Sub().who()
# Sub.who → call super:
# Base.who3、類方法與靜態(tài)方法
類方法可直接零參 super()(因?yàn)橛?cls):
class A:
@classmethod
def hello(cls):
print("A hello")
class B(A):
@classmethod
def hello(cls):
super().hello()
print("B hello")
B.hello()
# A hello
# B hello靜態(tài)方法中沒有隱式的 self/cls,零參 super() 不可用。但可以顯式兩參使用(調(diào)用無需實(shí)例的方法):
class A:
@classmethod
def ping(cls): print("A.ping")
class B(A):
@staticmethod
def call_ping():
# 顯式指定當(dāng)前類與類型參數(shù)
super(B, B).ping()
B.call_ping()
# A.ping若要在靜態(tài)方法中調(diào)用需要實(shí)例的方法,你必須自備實(shí)例并作為第二參傳入(或改為實(shí)例/類方法設(shè)計(jì))。
四、補(bǔ)充說明與常見誤區(qū)
1、誤把 super() 當(dāng)“父類調(diào)用”
它依賴 MRO,是當(dāng)前位置之后的下一個(gè)類;多繼承下若某類不調(diào)用 super(),調(diào)用鏈會(huì)被中斷。
2、靜態(tài)方法并非完全不能 super()
不能用零參,但可以顯式兩參(見上例)。關(guān)鍵是你是否有合適的第二參數(shù)以及要調(diào)用的是否為可在該上下文調(diào)用的方法(如 @classmethod)。
3、簽名與參數(shù)傳遞
在 __init__ 或其他需要鏈?zhǔn)秸{(diào)用的方法中,建議:
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
以免在多繼承組合時(shí)出現(xiàn)參數(shù)不匹配。
小結(jié)
super() 返回一個(gè)基于 MRO 的代理,不是“直接父類”的別名。
零參 super() 適用于實(shí)例方法與類方法;在靜態(tài)方法或特殊上下文中,可用顯式兩參。
在多繼承中配合合作式 super() 與一致的參數(shù)傳遞,能保證方法/構(gòu)造鏈完整運(yùn)行,避免菱形繼承中的重復(fù)與遺漏。
到此這篇關(guān)于Python中內(nèi)置函數(shù)super()用法的文章就介紹到這了,更多相關(guān)Python內(nèi)置函數(shù)super()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python中pivot()函數(shù)基礎(chǔ)知識(shí)點(diǎn)
在本篇內(nèi)容里小編給大家分享的是一篇關(guān)于python中pivot()函數(shù)基礎(chǔ)知識(shí)點(diǎn)內(nèi)容,對此有興趣的朋友們可以參考學(xué)習(xí)下。2021-01-01
numpy.random.shuffle打亂順序函數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了numpy.random.shuffle打亂順序函數(shù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
Python使用PyMuPDF(fitz)處理PDF文檔的操作指南
在Python中,PyMuPDF 是一個(gè)功能強(qiáng)大且高效的庫,用于處理多種文檔格式,尤其是PDF,它基于 MuPDF 引擎,提供了豐富的功能,包括文檔的讀取、寫入、修改、渲染和文本提取等,以下是一些關(guān)鍵用法和示例代碼,需要的朋友可以參考下2025-07-07
Python+LyScript實(shí)現(xiàn)自定義反匯編
LyScript?插件默認(rèn)提供了一個(gè)get_disasm_code()方法可以直接獲取到指定行數(shù)的反匯編代碼。本文將利用LyScript實(shí)現(xiàn)自定義反匯編,感興趣的可以了解一下2022-07-07
python機(jī)器學(xué)習(xí)sklearn實(shí)現(xiàn)識(shí)別數(shù)字
本文主要介紹了python機(jī)器學(xué)習(xí)sklearn實(shí)現(xiàn)識(shí)別數(shù)字,主要簡述如何通過sklearn模塊來進(jìn)行預(yù)測和學(xué)習(xí),最后再以圖表這種更加直觀的方式展現(xiàn)出來,感興趣的可以了解一下2022-03-03

