class A:
def __init__(self):
print('A')
class B(A):
def __init__(self):
print('B')
super().__init__()
抛出两个问题:
1.既然我们重写B的构造函数, 为什么还要去调用super?
> 因为很多时候我们需要父类定义的函数特性
2.super到底执行顺序是什么样的?
以菱形继承为例
class A:
def __init__(self):
print('A')
class B(A):
def __init__(self):
print('B')
super().__init__()
class C(A):
def __init__(self):
print('C')
super().__init__()
class D(B, C):
def __init__(self):
print('D')
super().__init__()
if __name__ == '__main__':
d=D()
#输出结果:
D
B
C
A
从结果可知,super不是真的调用父类,而是满足MRO的顺序的
因为如果super调用父类,那么在调用B之后,应该调用A,而实际上调用的是C
4-10 super真的是调用父类吗?
猜你喜欢
转载自blog.csdn.net/shfscut/article/details/80277226
今日推荐
周排行