Python中子類呼叫父類的初始化方法
轉自:https://blog.csdn.net/feishicheng/article/details/79596000
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()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
執行結果如下:
這時候就需要在類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__方法
- 方法二不太直觀,但可以解決多繼承問題,會一次性的執行所有的父類的對應方法
所以實際使用時,按照自己的需要選擇一個就行了。
---------------------
作者:feishicheng
來源:CSDN
原文:https://blog.csdn.net/feishicheng/article/details/79596000
版權宣告:本文為博主原創文章,轉載請附上博文連結!