Python實現子類呼叫父類的初始化例項
阿新 • • 發佈:2020-03-13
前言
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實現子類呼叫父類的初始化例項就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。