python 多继承

本文通过实例详细解析了Python中新式类的方法解析顺序(MRO)遵循的广度优先算法,并展示了如何通过代码验证这一顺序。同时,介绍了super()函数的工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在python继承中,新式类和旧式类的搜索顺序是不同的,旧式类是按照深度优先算法,此篇文章暂不讨论,新式类按照广度优先算法。上代码 举个例子

class P1 (object): 
   def foo(self):           
       print 'p1-foo' 

class P2 (object): 
   def foo(self): 
       print 'p2-foo' 
   def bar(self): 
       print 'p2-bar' 

class C1 (P1,P2): 
   pass  

class C2 (object): 
   def bar(self): 
       print 'C2-bar'   

class D(C1,C2): 
   pass 


d=D()
print D.__mro__

在这段代码中  按照 继承的顺序  拓扑图可以表示为

按照广度优先算法   顺序则为     D>C1>P1>P2>C2>object

我们打印 D的mro 结果如图

结果和我们计算一样

方法的 搜索也是这样

顺便说一下 super的原理

eg super(A, self).__init__()

在super内部

def super(cls, instance):

          return (instance.__class__.__mro__[instance.__class__.__mro__.index(cls) + 1])

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值