python多重继承
概念:
1.经典类: 申明的时候,没有继承于object,多重继承的时候,会按照深度优先方式查找
2.新式类:申明的时候,继承于object,多重继承的时候,会按照广度优先方式查找
但是!! python3之后默认所有的无论是否继承object,都默认 继承object,即python3中所有类均为新式类
所以得出结论,python3中的多重继承都是遵循广度优先的方式
classD():pass
classE():pass
classF():pass
classC(D, F):pass
classB(E, D):pass
classA(B, C):pass
if __name__ == '__main__':print( A.__mro__)
输出的是(, , , , , , )
排序方法:
先根据集成的左右优先级顺序画出图,然后先找到入度为0的,即:A,然后把A的所有链接点删除,从左到右找到
入度为0的,即:B,同理划掉B的所有连接点,下一个入度为0的就是E和C,这里采用广度优先,所以下一个是E,继续同理下去就能得到上述输出结果了。
super()
classA():def __init__(self):print("Enter A")print("Leave A")classB(A):def __init__(self):print("Enter B")
super(B, self).__init__()print("Leave B")classC(A):def __init__(self):print("Enter C")
super(C, self).__init__()print("Leave C")classD(A):def __init__(self):print("Enter D")
super(D, self).__init__()print("Leave D")classE(B, C, D):def __init__(self):print("Enter E")
super(E, self).__init__()print("Leave E")
E()
print(E.__mro__)
预期输出为:
Enter E
Enter B
Enter C
Enter D
Enter A
Leave A
Leave D
Leave C
Leave B
Leave E
(, , , , , )
梳理一下流程:
1.先执行E中的打印语句 ENTER,然后走到了第一个super()
2.根据继承关系,这里先走到B中,执行完B中的ENTER 打印语句后,又是一个super()继承,这里广度优先,所以走到C中,执行C的ENTER语句所以这里是关键,是走到C而不是看BC没有任何继承关系而去走到D
这里是按照__mro__顺序严格执行的,后续就是一步一步的执行输出如上