1. 程式人生 > 程式設計 >Python實現子類呼叫父類的初始化例項

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

執行結果如下:

Python實現子類呼叫父類的初始化例項

這時候就需要在類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()

執行結果如下:

Python實現子類呼叫父類的初始化例項

方法二:呼叫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()

執行結果如下:

Python實現子類呼叫父類的初始化例項

總結

兩種方法各有優缺點,但都可以解決問題。

- 方法一簡單直觀,但面對多繼承問題,只能多次呼叫每個父類的__init__方法

- 方法二不太直觀,但可以解決多繼承問題,會一次性的執行所有的父類的對應方法

所以實際使用時,按照自己的需要選擇一個就行了。

以上這篇Python實現子類呼叫父類的初始化例項就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。