MRO是Python通过C3线性化算法确定的类继承查找顺序,首项为自身、末项为object,调用__mro__或mro()可查看;C3确保子类优先、父类顺序一致且无冲突,否则报TypeError;super()严格按MRO调用下一方法。

Python的多重继承顺序由MRO(Method Resolution Order,方法解析顺序)决定,它不是简单按从左到右或深度优先排列,而是采用C3线性化算法生成一个确定、无歧义的继承链。理解MRO对避免属性/方法调用错误、调试继承冲突至关重要。
什么是MRO?
MRO是Python为每个类自动计算出的一个类序列,表示在查找属性或方法时应依次检查的类顺序。调用ClassName.__mro__或ClassName.mro()即可查看。
-
__mro__返回一个元组,只读;mro()返回一个列表,内容相同 - 序列首项总是该类自身,末项固定是
object - 所有父类必须出现在其子类之后,且满足“局部优先”和“单调性”约束
C3线性化如何工作?
C3算法确保:子类总比父类先被检查;多个父类按声明顺序保持相对位置;每个类的MRO是其父类MRO的“合并”,合并过程遵循头元素唯一且不在其余列表尾部的原则。
例如:
立即学习“Python免费学习笔记(深入)”;
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))。
如何判断和调试MRO问题?
当定义多层多重继承类时,若出现TypeError: Cannot create a consistent MRO,说明父类声明顺序导致C3无法生成有效线性化序列。
- 检查所有父类自身的MRO,确认它们是否对共享祖先类有不同排序
- 调整类定义中的继承顺序,使共同父类在各路径中位置一致
- 使用
print(YourClass.__mro__)快速验证结果 - 避免“钻石继承”中不一致的祖先声明,如
class X(A,B)和class Y(B,A)同时存在,再被同一子类继承
super()与MRO紧密配合
super()不是调用直接父类,而是沿MRO序列查找下一个匹配的方法。因此它的行为完全依赖MRO结果。
- 在
__init__中使用super().__init__()可保证所有父类初始化函数按MRO顺序执行一次 - 若手动写死
Parent.__init__(self),会绕过MRO,容易遗漏或重复调用 - 协程类、混合类(Mixin)尤其依赖
super()+ 正确MRO才能正常协作










