python多继承顺序及分配_Python中多重继承时方法解析顺序MRO(C3算法的应用)

在计算机科学中,C3算法主要用于确定多重继承时,子类应该继承哪一个父类的方法,即方法解析顺序(Method Resolution Order,MRO)。

C3算法实现了三种重要特性:

保持继承拓扑图的一致性,

保证局部优先原则(比如A继承B和C,C继承B,那么A读取父类方法,应该优先使用C的方法而不是B的方法)

保证单调性原则(即子类不改变父类的方法搜索顺序)

1996年的OOPSLA会议上,论文"A Monotonic Superclass Linearization for Dylan首次提出了C3超类线性化。被Python2.3选作方法解析的默认算法。

其他查找算法与C3算法的 比较:

深度优先:

深度优先带来的问题:假如C中重写了D中的方法,那么按照这个查找顺序就会出问题,我理应先使用C中的方法

深度优先

广度优先:

广度优先带来的问题:如果C中有跟D重名的方法,那么也会出现问题,如果我在B中找不到响应的方法,我理应去D中找

广度优先

C3

为解决上面的问题,python2.3开始采用c3算法:

C3

Python提供了__mor__和mor() 来查看类的方法解析顺序

以下的例子需在Python2.3及以后的版本上执行(本例使用Python3.5)

例子1:

class D(object):

pass

class C(D):

pass

class B(D):

pass

class A(B, C):

pass

print(A.__mro__)

# (, , ,

, )

例子2:

class D(object):

pass

class C(D):

pass

class B(D):

pass

class A(B, C):

pass

print(A.mro())

# [, , ,

, ]

例子3:

class D(object):

pass

class E(object):

pass

class C(E):

pass

class B(D):

pass

class A(B, C):

pass

print(A.__mro__)

# (, , ,

, , )

例子4

class B(object):

pass

class C(B):

pass

class A(C, B):

pass

print(A.__mro__)

例子5

class B(object):

pass

class C(B):

pass

class A(B,C):

pass

print(A.__mro__)

"""

说明:

这样写会报错:

TypeError: Cannot create a consistent method resolution

order (MRO) for bases B, C

"""

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值