什么是mro
多继承情况下,一个class如何从它的父类中找应该优先使用那个父类的函数,这个顺序就叫mro
mro介绍
mro时每一个类会把它所有的父类和自己做一个线性化,也就是把它继承的类和它自己做一个排队,排队是保证自己是最高优先级,当调用方法或寻找数据的时候,会按照这个队列的优先级顺序从前往后找。
mro的继承展示方式
寻找类的继承顺序有两种继承方式
1.类. __ mro __
2.类.mro()
介绍
当建立一个新的类,并继承了其它类的时候,他首先会根据这个继承关系计算出mro ,当尝试调用方法或使用这个类的数据的时候,他会根据这个mro依次的往前找,每一个在这个优先级列表上面的类,有没有这个方法或者有没有这个数据
mro算法
python从2.3版本开始,mro的算法就没有变过,使用的是c3算法
- MRO里任意两个类的相对顺序和自己所有父类的MRO里这两个类的相对顺序一致。(第三条,单调性)
- MRO里任意两个类的相对顺序和继承图里所有直接继承自这两个类的类在程序中声明的相对顺序一致。(第二条)
- 如果两个类不具有直接的继承关系,那么找到两个类的最小公共子类,这个最小公共子类的多继承顺序靠前的分支上的类具有高优先级。(第一条)
总结
- 如果两个类具有直接的继承关系,子类具有高优先级;
- 如果两个类不具有直接的继承关系,那么找到两个类的最小公共子类(同时继承自上述两个类,但所有父类都不同时继承上述两个类的类),这个最小公共子类的多继承顺序靠前的分支上的类具有高优先级