Python super()函數(shù)使用及多重繼承
super()函數(shù)可以用于繼承父類的方法,語法如下:
super(type[, object-or-type])
雖然super()函數(shù)的使用比較簡單,但是需要根據(jù)單繼承和多繼承來分析函數(shù)的調(diào)用關(guān)系。
首先,當(dāng)類之間的繼承關(guān)系為單繼承時(shí),函數(shù)調(diào)用關(guān)系也比較簡單,可以參考如下的例子:
#!/usr/bin/env python3class A(object): def __init__(self): print(’class A’)class B(A): def __init__(self): super(B, self).__init__() print(’class B’)b = B()
上述代碼運(yùn)行結(jié)果如下:
class Aclass B
從結(jié)果可以看出,子類B在實(shí)例化時(shí)調(diào)用了父類A的__init__()方法。
當(dāng)進(jìn)行多重繼承時(shí),需要考慮MRO的問題。所謂MRO,即Method Resolution Order,自Python2.3以來,MRO采用廣度優(yōu)先(區(qū)別于深度優(yōu)先)的規(guī)則定義。為了更好的理解這個(gè)問題,讓我們先來看如下的代碼:
#!/usr/bin/env python3class A(object): def __init__(self): self.n = 10 def minus(self, m): print(’minus in class A start’) self.n -= m print(’minus in class A end’)class B(A): def __init__(self): self.n = 7 def minus(self, m): print(’minus in class B start’) super(B, self).minus(m) self.n -= 2 print(’minus in class B end’)class C(A): def __init__(self): self.n = 12 def minus(self, m): print(’minus in class C start’) super(C, self).minus(m) self.n -= 5 print(’minus in class C end’)class D(B,C): def __init__(self): self.n = 15 def minus(self, m): print(’minus in class D start’) super(D, self).minus(m) self.n -= 2 print(’minus in class D end’)print(’The MRO of class D is :’)print(D.__mro__)d = D()d.minus(2)print(d.n)
代碼運(yùn)行結(jié)果:
The MRO of class D is :(<class ’__main__.D’>, <class ’__main__.B’>, <class ’__main__.C’>, <class ’__main__.A’>, <class ’object’>)minus in class D startminus in class B startminus in class C startminus in class A startminus in class A endminus in class C endminus in class B endminus in class D end4
從運(yùn)行結(jié)果可以看出,子類D的MRO為(<class ’__main__.D’>, <class ’__main__.B’>, <class ’__main__.C’>, <class ’__main__.A’>, <class ’object’>),也就是子類D的minus函數(shù)在調(diào)用父類函數(shù)時(shí)的調(diào)用順序依次為BCA,而后續(xù)的調(diào)試打印信息也正好驗(yàn)證了該順序。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 利用CSS3新特性創(chuàng)建透明邊框三角2. html清除浮動(dòng)的6種方法示例3. CSS代碼檢查工具stylelint的使用方法詳解4. Vue3使用JSX的方法實(shí)例(筆記自用)5. vue實(shí)現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程6. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)7. 詳解CSS偽元素的妙用單標(biāo)簽之美8. 使用css實(shí)現(xiàn)全兼容tooltip提示框9. JavaScript數(shù)據(jù)類型對(duì)函數(shù)式編程的影響示例解析10. 不要在HTML中濫用div
