记一下python的method resolution order(MRO)机制

一直用python都是拿着cookbook和库的文档直接撸,很少会把细节过得那么彻底,遇到问题才会翻文档。

今天看到这个例子的时候我突然触及了我的盲区,我不确定这样的继承层级调用super.foo()会先绑定哪个。因为之前我写的库的类层级并不会这样,所以没有去考究。

既然遇到问题,就要去弄明白、去解决这个问题。看了官方的文档,python在多继承的情况下,会先将父类的继承链路全部放进一个list里面,然后再进行合并,再函数绑定的时候,左前到后遇到第一个匹配的时候直接绑定。

下面po出代码。


class A:
def foo(self):
print("A")


class B(A):
def foo(self):
super(B, self).foo()
print("B")


class C(B, A):
def foo(self):
super(C, self).foo()
print("C")


class D(C):
def foo(self):
super(D, self).foo()
print("D")


class E(D, C):
pass


a = A()
b = B()
c = C()
d = D()
e = E()

a.foo()
print(" ")
b.foo()
print(" ")
c.foo()
print(" ")
d.foo()
print(" ")
e.foo()
 

答案:

根据文档的计算方法

L(A) = O

L(B) = B  A O

L(C) = C  merge(BAO,AO,BA) = C B A O

L(D) = D C B A O

L(E) = E + merge(DCBAO,CBAO,DC)  = E D C B A O

 

所以super(type,self).foo()绑定的方法实例就会按照上面的解来得出。

 

posted @ 2019-09-11 01:44  JasonKoo  阅读(378)  评论(0编辑  收藏  举报