python中super()方法的解釋


在學習 Python 類的時候,會碰見類中有 __init__() 這樣一個函數,其實它就是 Python 的構造方法。

構造方法類似於類似 init() 這種初始化方法,來初始化新創建對象的狀態,在一個對象創建后會立即調用,比如像實例化一個類:

f = FooBar()
f.init()#手動初始化

使用構造方法就能讓它簡化成如下形式:對象創建后自動調用魔法方法__init__(),對對象進行初始化操作

f = FooBar()

在明白了構造方法之后,來點進階的問題,那就是父類的構造方法中的初始值無法繼承的問題

class Bird:
    def __init__(self):
          self.hungry = True
    def eat(self):
          if self.hungry:
               print 'Ahahahah'
          else:
               print 'No thanks!'

class SongBird(Bird):
     def __init__(self):
          self.sound = 'Squawk'
     def sing(self):
          print self.song()

sb = SongBird()
sb.sing()    # 能正常輸出
sb.eat()     # 報錯,因為 songgird 中沒有 hungry 特性

解決這個問題的辦法有兩種:

1、調用未綁定的超類構造方法(不推薦)

class SongBird(Bird):
     def __init__(self):
          Bird.__init__(self) #
          self.sound = 'Squawk'
     def sing(self):
          print self.song()

原理在調用了一個實例的方法時,該方法的self參數會自動綁定到實例上(稱為綁定方法);如果直接調用類的方法(比如Bird.__init__),那么就沒有實例會被綁定,可以自由提供需要的self參數(未綁定方法)。

2、使用super函數(推薦)

class SongBird(Bird):
     def __init__(self):
         super(SongBird,self).__init__()
          self.sound = 'Squawk'
     def sing(self):
          print self.song()

原理:它會查找所有的超類,以及超類的超類,直到找到所需的特性為止。

 

super() 函數是用於調用父類(超類)的一個方法。

super 是用來解決多重繼承問題的,直接用類名調用父類方法在使用單繼承的時候沒問題,但是如果使用多繼承,會涉及到查找順序(MRO)、重

復調用(鑽石繼承)等種種問題。

MRO 就是類的方法解析順序表, 其實也就是繼承父類方法時的順序表。(菜鳥文檔)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM