Python實現子類調用父類的方法

來源:互聯網
上載者:User
本文執行個體講述了Python實現子類調用父類的方法。分享給大家供大家參考。具體實現方法如下:

python和其他物件導向語言類似,每個類可以擁有一個或者多個父類,它們從父類那裡繼承了屬性和方法。如果一個方法在子類的執行個體中被調用,或者一個屬性在子類的執行個體中被訪問,但是該方法或屬性在子類中並不存在,那麼就會自動的去其父類中進行尋找。

繼承父類後,就能調用父類方法和訪問父類屬性,而要完成整個整合過程,子類是需要調用的建構函式的。

子類不顯式調用父類的構造方法,而父類建構函式初始化了一些屬性,就會出現問題
如果子類和父類都有建構函式,子類其實是重寫了父類的建構函式,如果不顯式調用父類建構函式,父類的建構函式就不會被執行,導致子類執行個體訪問父類初始化方法中初始的變數就會出現問題。

先來看看如下樣本:

代碼如下:

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()


運行結果:

代碼如下:

bbb

function b : bbb
Traceback (most recent call last):
File "D:workbenchpythonMyPythonProjectteststudyoverwrite_method.py", line 19, in
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'


在子類中,建構函式被重寫,但新的構造方法沒有任何關於初始化父類的namea屬性的代碼,為了達到預期的效果,子類的構造方法必須調用其父類的構造方法來進行基本的初始化。有兩種方法能達到這個目的:調用超類構造方法的未綁定版本,或者使用super函數。

方法一:調用未綁定的超類構造方法

修改代碼,多增一行:

代碼如下:

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"
def funcb(self):
print "function b : %s"%self.nameb
b=B()
print b.nameb
b.funcb()
b.funca()


如上有注釋的一行解決了該問題,直接使用父類名稱調用其建構函式即可。

這種方法叫做調用父類的未綁定的構造方法。在調用一個執行個體的方法時,該方法的self參數會被自動綁定到執行個體上(稱為Binder 方法)。但如果直接調用類的方法(比如A.__init),那麼就沒有執行個體會被綁定。這樣就可以自由的提供需要的self參數,這種方法稱為未綁定unbound方法。
通過將當前的執行個體作為self參數提供給未Binder 方法,B類就能使用其父類構造方法的所有實現,從而namea變數被設定。

方法二:使用super函數

修改代碼,這次需要增加在原來代碼上增加2行:

代碼如下:

#父類需要繼承object對象
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函數,因為這是python的“新式類”支援的特性。當前的雷和對象可以作為super函數的參數使用,調用函數返回的對象的任何方法都是調用超類的方法,而不是當前類的方法。

super函數會返回一個super對象,這個對象負責進行方法解析,解析過程其會自動尋找所有的父類以及父類的父類。

方法一更直觀,方法二可以一次初始化所有超類

super函數比在超累中直接調用未Binder 方法更直觀,但是其最大的有點是如果子類繼承了多個父類,它只需要使用一次super函數就可以。然而如果沒有這個需求,直接使用A.__init__(self)更直觀一些。

希望本文所述對大家的Python程式設計有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.