关于super()
class A():def __init__(self):
print("进入A…")
print("离开A…")
class B(A):
def __init__(self):
print("进入B…")
super().__init__()
print("离开B…")
class C(A):
def __init__(self):
print("进入C…")
super().__init__()
print("离开C…")
class D(B, C):
def __init__(self):
print("进入D…")
super().__init__()
print("离开D…")
为啥使用了super后打印得顺序,跟用A.__init()__(self)的不一样了? 这应该是涉及 MRO 的顺序问题吧,推荐你看下小甲鱼老师的扩展阅读,还有下面两个文章:
[扩展阅读] 多重继承的陷阱:钻石继承(菱形继承)问题
钻石继承(菱形继承)
Python菱形继承的初始化问题和继承顺序
MRO顺序本质上执行的是广度优先搜索,从左到右,搜索完同一层级的时候,向上爬升。
保证了每个类中的方法只会被执行一次。避免了同一个类被调用多次的情况。
就是因为使用super()函数调用的是在按照 MRO 顺序中的直接查找父类,避免被多次继承引发不必要的危害
而你直接用 类名.__init__ 调用父类方法实际上就是按照原来代码的顺序,一个个执行下去,这样就会导致继承过程中同时多次继承同个类
这种死亡钻石一辈子也用不上几次,了解原理就行,不用深追。
页:
[1]