本文實(shí)例講述了Python實(shí)現(xiàn)子類調(diào)用父類的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
python和其他面向?qū)ο笳Z言類似,每個(gè)類可以擁有一個(gè)或者多個(gè)父類,它們從父類那里繼承了屬性和方法。如果一個(gè)方法在子類的實(shí)例中被調(diào)用,或者一個(gè)屬性在子類的實(shí)例中被訪問,但是該方法或?qū)傩栽谧宇愔胁⒉淮嬖冢敲淳蜁?huì)自動(dòng)的去其父類中進(jìn)行查找。
繼承父類后,就能調(diào)用父類方法和訪問父類屬性,而要完成整個(gè)集成過程,子類是需要調(diào)用的構(gòu)造函數(shù)的。
子類不顯式調(diào)用父類的構(gòu)造方法,而父類構(gòu)造函數(shù)初始化了一些屬性,就會(huì)出現(xiàn)問題
如果子類和父類都有構(gòu)造函數(shù),子類其實(shí)是重寫了父類的構(gòu)造函數(shù),如果不顯式調(diào)用父類構(gòu)造函數(shù),父類的構(gòu)造函數(shù)就不會(huì)被執(zhí)行,導(dǎo)致子類實(shí)例訪問父類初始化方法中初始的變量就會(huì)出現(xiàn)問題。
先來看看如下示例:
代碼如下:class A:
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()
運(yùn)行結(jié)果:
代碼如下:bbb
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屬性的代碼,為了達(dá)到預(yù)期的效果,子類的構(gòu)造方法必須調(diào)用其父類的構(gòu)造方法來進(jìn)行基本的初始化。有兩種方法能達(dá)到這個(gè)目的:調(diào)用超類構(gòu)造方法的未綁定版本,或者使用super函數(shù)。
方法一:調(diào)用未綁定的超類構(gòu)造方法
修改代碼,多增一行:
代碼如下:class A:
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"
新聞熱點(diǎn)
疑難解答
圖片精選