首页 > 编程语言 > 详细

python中多继承C3算法研究

时间:2019-03-27 19:26:46      阅读:118      评论:0      收藏:0      [点我收藏+]

在python的面向对象继承问题中,单继承简单易懂,全部接受传承类的属性,并可添加自带属性,

但是,在多继承情况下,会遇到多个被继承者的顺序问题,以及多次继承后查找前几次继承者需求属性时,可能不易发现

99%的多继承可以通过肉眼推测被继承者路径,逐级返回查找需求,但是又有一部分因为继承次数多,被继承几经转折,而不好区分,易被误导,

在这时,可以使用C3算法分析,目前心得记录下,以后遇到温习,补充:
99%看: C3算法在python3中以广度优先为基本原则,

  怎         1.先按继承先后顺序,走先继承者一条路径,

  么                  如遇到下一级被继承者可以被别的路径到达,停止,(遵循广度优先原则,) 回到第二位继承者分支路重新出发

                      走到前面停止位时,如果只有自己能连接到,通过继续走,中途遇到可以被别的路到达情况,继续让路重来,让后来者
  看        2.逐次等待后来路走完所有路后,最后一条到达最初被继承者,找到需求.

                 技术分享图片 

C3算法原理
技术分享图片

验证自己的继承推断时候出错,可以用python.mro()打印查看
将被继承者逐级写出类公式,求最后以位继承者.mro()
技术分享图片

目前也就者理解呢,慢慢学习ing!!!

 

 

 

 

 

 

 

 

 

 

 

                               

python中多继承C3算法研究

原文:https://www.cnblogs.com/OB19227/p/10609717.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!