黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

解決python super()調用多重繼承函數的問題

系統 1891 0

當類間繼承關系很簡單時,super()的使用很簡單。

            
class A(object):
 def __init__(self):
  print('a')
 
 
class B(A):
 def __init__(self):
  super(B, self).__init__()
  print('b')
 
b = B()
          

輸出結果:

            
a
b
          

當一個類繼承多個類時,問題就復雜起來了,請看下例:

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

咋一看,情況好像也不復雜,結果輸出a, c嘛。沒錯!但是如果C類想同時調用A與B的__init__()呢?

有童鞋就要說了,我顯示調用不就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()


          

效果一樣,還不夠好。因為沒有調用super(),super的一大好處在于,當父類的名字修改時,其繼承類不用修改調用方法。

下面給出完美解決方案:

            
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()),在實際中可以去掉,為啥寫在這里,后面再說。

輸出結果:

            
[
            
              , 
              
                , 
                
                  , 
                  
                    ]
b
a
c
                  
                
              
            
          

注意:輸出結果是b, a, c 而非a, b, c。為什么?

這里就要用上面的mro()輸出來解釋了。MRO全稱Method Resolution Order, 就是用來定義繼承方法的調用順序,自Python2.3以來,MRO采用廣度優先(區別于深度優先)的規則定義。按廣度優先的規則,出來的順序就是:

            
[
            
              , 
              
                , 
                
                  , 
                  
                    ]
                  
                
              
            
          

而每次調用super()則是,調用MRO中下一個函數。上面的例子中:super(C, self)則指向MRO中的下一個類(A), 于是調用A的init --> 在A的init中,又調用了super(),于是調用MRO中的下一個函數(B) --> B調用下一個(object), object啥也不干 --> 返回B中,print('b') --> 返回A中,print('a') --> 返回C中,print('c')。

這里再次強調一次,super(type, obj).func()函數調用的是,obj實例在MRO中下一個父類的可調用func(),而不是type的父類中的func()(這個是本文第一個示例給你帶來的錯覺)。

以上這篇解決python super()調用多重繼承函數的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!?。?/p>

發表我的評論
最新評論 總共0條評論