Python實現子類調用父類的初始化實例
前言
python中進行面向對象編程,當在子類的實例中調用父類的屬性時,由于子類的__init__方法重寫了父類的__init__方法,如果在子類中這些屬性未經過初始化,使用時就會出錯。
例如以下的代碼:
class A(object): def __init__(self): self.a = 5 def function_a(self): print(’I am from A, my value is %d’ % self.a)class B(A): def __init__(self): self.b = 10 def function_b(self): print(’I am from B, my value is %d’ % self.b) self.function_a() # 調用類A的方法,出錯if __name__ == ’__main__’: b = B() b.function_b()
執行結果如下:
這時候就需要在類B的__init__方法中先執行類A的__init__方法,腳本才可以正確執行。Python提供了兩種方法來完成這個任務。
方法一: 調用未綁定的父類__init__方法
在類的方法定義時,首個參數均為self。當實例化這個類時,self就被自動綁定到當前的實例。綁定也就意味著這個實例的屬性,方法都可以通過‘self.***的方式進行調用。但是如果通過類名直接調用類的方法,self參數就不會被自動綁定到實例上,可以綁定到我們指定的實例上。也就是子類的實例上,在這里就是類B了。
所以這里所說的未綁定的父類__init__方法 就是指未綁定父類實例的父類__init__方法。
具體的代碼如下:
class A(object): def __init__(self): self.a = 5 def function_a(self): print(’I am from A, my value is %d’ % self.a)class B(A): def __init__(self): A.__init__(self) # 此處修改了。如果類A的__init__方法需要傳參,也需要傳入對應的參數 self.b = 10 def function_b(self): print(’I am from B, my value is %d’ % self.b) self.function_a()if __name__ == ’__main__’: b = B() b.function_b()
執行結果如下:
方法二:調用super函數
super函數是用于調用父類的一個方法,主要是用于解決多繼承問題,避免多繼承帶來的一些問題,當然也可以用來解決單繼承問題,調用父類的__init__方法了。
具體代碼如下:
class A(object): def __init__(self): self.a = 5 def function_a(self): print(’I am from A, my value is %d’ % self.a)class B(A): def __init__(self): super(B, self).__init__() # 此處修改了 self.b = 10 def function_b(self): print(’I am from B, my value is %d’ % self.b) self.function_a()if __name__ == ’__main__’: b = B() b.function_b()
執行結果如下:
總結
兩種方法各有優缺點,但都可以解決問題。
- 方法一簡單直觀,但面對多繼承問題,只能多次調用每個父類的__init__方法
- 方法二不太直觀,但可以解決多繼承問題,會一次性的執行所有的父類的對應方法
所以實際使用時,按照自己的需要選擇一個就行了。
以上這篇Python實現子類調用父類的初始化實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章: