MRO是Python通过C3线性化算法确定的类继承查找顺序,首项为自身、末项为object,调用__mro__或mro()可查看;C3确保子类优先、父类顺序一致且无冲突,否则报TypeError;super()严格按MRO调用下一方法。
Python的多重继承顺序由MRO(Method Resolution Order,方法解析顺序)决定,它不是简单按从左到右或深度优先排列,而是采用C3线性化算法生成一个确定、无歧义的继承链。理解MRO对避免属性/方法调用错误、调试继承冲突至关重要。
MRO是Python为每个类自动计算出的一个类序列,表示在查找属性或方法时应依次检查的类顺序。调用ClassName.__mro__或ClassName.mro()即可查看。
__mro__返回一个元组,只读;mro()返回一个列表,内容相同object
C3算法确保:子类总比父类先被检查;多个父类按声明顺序保持相对位置;每个类的MRO是其父类MRO的“合并”,合并过程遵循头元素唯一且不在其余列表尾部的原则。
例如:
class A: pass class B: pass class C(A, B): pass class D(B, A): pass class E(C, D): pass
此时E.mro()不会是[E, C, A, B, D, ...]——因为D也继承自B和A,而A在D的MRO中位于B之后,与C中顺序冲突,C3会拒绝这种矛盾并重新计算,最终得到合法线性序列(实际运行会报错TypeError: Cannot create a consistent method resolution order (MRO))。
当定义多层多重继承类时,若出现TypeError: Cannot create a consistent MRO,说明父类声明顺序导致C3无法生成有效线性化序列。
print(YourClass.__mro__)快速验证结果class X(A,B)和class Y(B,A)同时存在,再被同一子类继承super(不是调用直接父类,而是沿MRO序列查找下一个匹配的方法。因此它的行为完全依赖MRO结果。
)
__init__中使用super().__init__()可保证所有父类初始化函数按MRO顺序执行一次Parent.__init__(self),会绕过MRO,容易遗漏或重复调用super() + 正确MRO才能正常协作