這篇文章給大家介紹python中怎么實現(xiàn)繼承與多重繼承,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站建設服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)永善免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千余家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉變。記住以下幾點:
直接子類化內(nèi)置類型(如dict,list或str)容易出錯,因為內(nèi)置類型的方法通常會忽略用戶覆蓋的方法,不要子類化內(nèi)置類型,用戶自定義的類應該繼承collections模塊。
def __setitem__(self, key, value): super().__setitem__(key, [value] * 2) # 錯誤案例 class AnswerDict(dict): def __getitem__(self, item): # 錯誤案例 return 42 import collections class DoppelDict2(collections.UserDict): # 正確案例 def __setitem__(self, key, value): super().__setitem__(key, [value] * 2) class AnswerDict2(collections.UserDict): # 正確案例 def __getitem__(self, item): return 42
多重繼承有關的另一個問題就是:如果同級別的超類定義了同名屬性.Python如何確定使用哪個?
class DoppelDict(dict): def __setitem__(self, key, value): super().__setitem__(key, [value] * 2) class AnswerDict(dict): def __getitem__(self, item): return 42 import collections class DoppelDict2(collections.UserDict): def __setitem__(self, key, value): super().__setitem__(key, [value] * 2) class AnswerDict2(collections.UserDict): def __getitem__(self, item): return 42 class A: def ping(self): print('Ping:', self) class B(A): def pong(self): print('pong:', self) class C(A): def pong(self): print('PONG:', self) class D(B, C): def ping(self): super().ping() print('post-ping:', self) def pingpong(self): self.ping() super().ping() self.pong() super().pong() C.pong(self) if __name__ == '__main__': d = D() print(d.pong()) # 輸出來源于B print(C.pong(d)) #輸出來源于C 超類的方法都可以直接調(diào)用,此時要把實例作為顯示參數(shù)傳入.
python能區(qū)別調(diào)用的是哪個方法,通過方法解析順序
>>> D.mro()
[
若想把方法調(diào)用委托給超類,推薦的方式是使用內(nèi)置的super()函數(shù).
以下是對于d.pingpong()方法的解讀
>>> self.ping()
Ping: <__main__.D object at 0x000002213877F2B0> post-ping: <__main__.D object at 0x000002213877F2B0> 第一個調(diào)用的是self.ping(),運行的是是D類的ping,方法.
第二個調(diào)用的的是super().ping(),跳過D類的ping方法,找到A類的ping方法.Ping: <__main__.D object at 0x000002213877F2B0>
第三個調(diào)用的是self.pong()方法,根據(jù)__mro__,找到B類實現(xiàn)的pong方法. pong: <__main__.D object at 0x000002213877F2B0>
第四個調(diào)用時super().pong(),也是根據(jù)__mro__,找到B類實現(xiàn)的pong方法. pong: <__main__.D object at 0x000002213877F2B0>
第五個調(diào)用的是C.pong(self),忽略了__mro__,找到的是C類實現(xiàn)的pong方法. PONG: <__main__.D object at 0x000002213877F2B0>
關于python中怎么實現(xiàn)繼承與多重繼承就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。