Python實現(xiàn)子類調(diào)用父類的方法
本文實例講述了Python實現(xiàn)子類調(diào)用父類的方法。分享給大家供大家參考。具體實現(xiàn)方法如下:
python和其他面向?qū)ο笳Z言類似,每個類可以擁有一個或者多個父類,它們從父類那里繼承了屬性和方法。如果一個方法在子類的實例中被調(diào)用,或者一個屬性在子類的實例中被訪問,但是該方法或?qū)傩栽谧宇愔胁⒉淮嬖?,那么就會自動的去其父類中進行查找。
繼承父類后,就能調(diào)用父類方法和訪問父類屬性,而要完成整個集成過程,子類是需要調(diào)用的構(gòu)造函數(shù)的。
子類不顯式調(diào)用父類的構(gòu)造方法,而父類構(gòu)造函數(shù)初始化了一些屬性,就會出現(xiàn)問題
如果子類和父類都有構(gòu)造函數(shù),子類其實是重寫了父類的構(gòu)造函數(shù),如果不顯式調(diào)用父類構(gòu)造函數(shù),父類的構(gòu)造函數(shù)就不會被執(zhí)行,導(dǎo)致子類實例訪問父類初始化方法中初始的變量就會出現(xiàn)問題。
先來看看如下示例:
def __init__(self):
self.namea="aaa"
def funca(self):
print "function a : %s"%self.namea
class B(A):
def __init__(self):
self.nameb="bbb"
def funcb(self):
print "function b : %s"%self.nameb
b=B()
print b.nameb
b.funcb()
b.funca()
運行結(jié)果:
function b : bbb
Traceback (most recent call last):
File "D:workbenchpythonMyPythonProjectteststudyoverwrite_method.py", line 19, in <module>
print b.funca()
File "D:workbenchpythonMyPythonProjectteststudyoverwrite_method.py", line 6, in funca
print "function a : %s"%self.namea
AttributeError: B instance has no attribute 'namea'
在子類中,構(gòu)造函數(shù)被重寫,但新的構(gòu)造方法沒有任何關(guān)于初始化父類的namea屬性的代碼,為了達到預(yù)期的效果,子類的構(gòu)造方法必須調(diào)用其父類的構(gòu)造方法來進行基本的初始化。有兩種方法能達到這個目的:調(diào)用超類構(gòu)造方法的未綁定版本,或者使用super函數(shù)。
方法一:調(diào)用未綁定的超類構(gòu)造方法
修改代碼,多增一行:
def __init__(self):
self.namea="aaa"
def funca(self):
print "function a : %s"%self.namea
class B(A):
def __init__(self):
#這一行解決了問題
A.__init__(self)
self.nameb="bbb"
def funcb(self):
print "function b : %s"%self.nameb
b=B()
print b.nameb
b.funcb()
b.funca()
如上有注釋的一行解決了該問題,直接使用父類名稱調(diào)用其構(gòu)造函數(shù)即可。
這種方法叫做調(diào)用父類的未綁定的構(gòu)造方法。在調(diào)用一個實例的方法時,該方法的self參數(shù)會被自動綁定到實例上(稱為綁定方法)。但如果直接調(diào)用類的方法(比如A.__init),那么就沒有實例會被綁定。這樣就可以自由的提供需要的self參數(shù),這種方法稱為未綁定unbound方法。
通過將當前的實例作為self參數(shù)提供給未綁定方法,B類就能使用其父類構(gòu)造方法的所有實現(xiàn),從而namea變量被設(shè)置。
方法二:使用super函數(shù)
修改代碼,這次需要增加在原來代碼上增加2行:
class A(object):
def __init__(self):
self.namea="aaa"
def funca(self):
print "function a : %s"%self.namea
class B(A):
def __init__(self):
#這一行解決問題
super(B,self).__init__()
self.nameb="bbb"
def funcb(self):
print "function b : %s"%self.nameb
b=B()
print b.nameb
b.funcb()
b.funca()
如上有注釋的為新增的代碼,其中第一句讓類A繼承自object類,這樣才能使用super函數(shù),因為這是python的“新式類”支持的特性。當前的雷和對象可以作為super函數(shù)的參數(shù)使用,調(diào)用函數(shù)返回的對象的任何方法都是調(diào)用超類的方法,而不是當前類的方法。
super函數(shù)會返回一個super對象,這個對象負責(zé)進行方法解析,解析過程其會自動查找所有的父類以及父類的父類。
方法一更直觀,方法二可以一次初始化所有超類
super函數(shù)比在超累中直接調(diào)用未綁定方法更直觀,但是其最大的有點是如果子類繼承了多個父類,它只需要使用一次super函數(shù)就可以。然而如果沒有這個需求,直接使用A.__init__(self)更直觀一些。
希望本文所述對大家的Python程序設(shè)計有所幫助。
相關(guān)文章
Linux下python與C++使用dlib實現(xiàn)人臉檢測
這篇文章主要為大家詳細介紹了Linux下python與C++使用dlib實現(xiàn)人臉檢測,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06Python簡單實現(xiàn)查找一個字符串中最長不重復(fù)子串的方法
這篇文章主要介紹了Python簡單實現(xiàn)查找一個字符串中最長不重復(fù)子串的方法,涉及Python針對字符串的簡單遍歷、運算等相關(guān)操作技巧,需要的朋友可以參考下2018-03-03VS2022安裝Python開發(fā)環(huán)境的詳細過程
這篇文章主要介紹了VS2022安裝Python開發(fā)環(huán)境,文中用Python實現(xiàn)裴波那契數(shù)列,來感受一下Python的魅力,結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2022-08-08Flask框架實現(xiàn)給視圖函數(shù)增加裝飾器操作示例
這篇文章主要介紹了Flask框架實現(xiàn)給視圖函數(shù)增加裝飾器操作,結(jié)合實例形式分析了flask框架視圖添加裝飾器的具體操作方法及相關(guān)注意事項,需要的朋友可以參考下2018-07-07