python学习-C3算法

C3算法是多重继承中,解决对资源的索引顺序。

C3算法是python2.3开始使用的,解决python2.2以前版本的深度优先中重写无效问题以及python2.3版本中广度优先中的单调性问题。


C3算法:

L(class) = [class] + merge(L(base_1)+L(base_2)+...+L(base_n) + [base_1 + base_2 + ...+base_n])

算法执行过程:

遍历merge中各个列表,当列表的第一个数据,在其他列表中也是同一个数据 或者 其他列表中没有这个数据,则把这个数据提到merge前面的列表中append进去。而在merge里面的这些列表,都把该数据删除;

知道merge中所有序列都为空,则merge前面的列表就是它的方法解释顺序。

如果最后merge中还存在不为空的列表,则说明该类的继承关系存在问题!

C3算法与拓扑算法的区别:

拓扑算法未考虑基类出现的先后顺序。

  在特定的继承关系下,通过拓扑算法分析出的解释顺序与C3算法计算出的解释顺序不一致。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值