當(dāng)類(lèi)間繼承關(guān)系很簡(jiǎn)單時(shí),super()的使用很簡(jiǎn)單。
class A(object): def __init__(self): print('a') class B(A): def __init__(self): super(B, self).__init__() print('b') b = B()
輸出結(jié)果:
a b
當(dāng)一個(gè)類(lèi)繼承多個(gè)類(lèi)時(shí),問(wèn)題就復(fù)雜起來(lái)了,請(qǐng)看下例:
class A(object): def __init__(self): print('a') class B(object): def __init__(self): print('b') class C(A, B): def __init__(self): super(C, self).__init__() print('c') c = C()
咋一看,情況好像也不復(fù)雜,結(jié)果輸出a, c嘛。沒(méi)錯(cuò)!但是如果C類(lèi)想同時(shí)調(diào)用A與B的__init__()呢?
有童鞋就要說(shuō)了,我顯示調(diào)用不就OK了嘛?
class A(object): def __init__(self): print('a') class B(object): def __init__(self): print('b') class C(A, B): def __init__(self): A.__init__() B.__init__() print('c') c = C()
效果一樣,還不夠好。因?yàn)闆](méi)有調(diào)用super(),super的一大好處在于,當(dāng)父類(lèi)的名字修改時(shí),其繼承類(lèi)不用修改調(diào)用方法。
下面給出完美解決方案:
class A(object): def __init__(self): super(A, self).__init__() print('a') class B(object): def __init__(self): super(B, self).__init__() print('b') class C(A, B): def __init__(self): super(C, self).__init__() print('c') print(C.mro()) c = C()
print(C.mro()),在實(shí)際中可以去掉,為啥寫(xiě)在這里,后面再說(shuō)。
輸出結(jié)果:
[, , , ] b a c
注意:輸出結(jié)果是b, a, c 而非a, b, c。為什么?
這里就要用上面的mro()輸出來(lái)解釋了。MRO全稱(chēng)Method Resolution Order, 就是用來(lái)定義繼承方法的調(diào)用順序,自Python2.3以來(lái),MRO采用廣度優(yōu)先(區(qū)別于深度優(yōu)先)的規(guī)則定義。按廣度優(yōu)先的規(guī)則,出來(lái)的順序就是:
[, , , ]
而每次調(diào)用super()則是,調(diào)用MRO中下一個(gè)函數(shù)。上面的例子中:super(C, self)則指向MRO中的下一個(gè)類(lèi)(A), 于是調(diào)用A的init --> 在A的init中,又調(diào)用了super(),于是調(diào)用MRO中的下一個(gè)函數(shù)(B) --> B調(diào)用下一個(gè)(object), object啥也不干 --> 返回B中,print('b') --> 返回A中,print('a') --> 返回C中,print('c')。
這里再次強(qiáng)調(diào)一次,super(type, obj).func()函數(shù)調(diào)用的是,obj實(shí)例在MRO中下一個(gè)父類(lèi)的可調(diào)用func(),而不是type的父類(lèi)中的func()(這個(gè)是本文第一個(gè)示例給你帶來(lái)的錯(cuò)覺(jué))。
以上這篇解決python super()調(diào)用多重繼承函數(shù)的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
