python 多重继承的方法解析顺序

python 多重继承的方法解析顺序

任何实现多重继承的语言都要处理潜在的命名冲突, 这种冲突由不相关的祖先类实现同名方法引起

 


 
 
  1. class A:
  2. def say(self):
  3. print( "A Hello:", self)
  4. class B(A):
  5. def eat(self):
  6. print( "B Eating:", self)
  7. class C(A):
  8. def eat(self):
  9. print( "C Eating:", self)
  10. class D(B, C):
  11. def say(self):
  12. super().say()
  13. print( "D Hello:", self)
  14. def dinner(self):
  15. self.say()
  16. super().say()
  17. self.eat()
  18. super().eat()
  19. C.eat(self)

 

这里B和C都实现了eat方法,

在 D 的实例上调用 d.eat() 方法的话, 运行的是哪个 eat 方法呢?


 
 
  1. >>> d = D()
  2. >>> d.eat()
  3. B Eating: <__main__.D object at 0x7fb90c627f60>
  4. >>> C.eat(d)
  5. C Eating: <__main__.D object at 0x7fb90c627f60>
  6. 超类中的方法都可以直接调用, 此时要把实例作为显式参数传入


Python 能区分 d.eat() 调用的是哪个方法, 是因为 Python 会按照特定的顺序遍历继承图。 这个顺序叫方法解析顺序( Method Resolution Order, MRO)。 类都有一个名为 __mro__ 的属性, 它的值是一个元组, 按照方法解析顺序列出各个超类, 从当前类一直向上, 直到object 类。 D 类的 __mro__ 属性如下 :

 


 
 
  1. >>> D.__mro__
  2. (< class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <class 'object'>)

 


 
 
  1. >>> d = D()
  2. >>> d.dinner()
  3. A Hello: <__main__.D object at 0x7fb90bd7eb70>
  4. D Hello: <__main__.D object at 0x7fb90bd7eb70>
  5. A Hello: <__main__.D object at 0x7fb90bd7eb70>
  6. B Eating: <__main__.D object at 0x7fb90bd7eb70>
  7. B Eating: <__main__.D object at 0x7fb90bd7eb70>
  8. C Eating: <__main__.D object at 0x7fb90bd7eb70>
  9. 第一个self.say(),运行A类的say()再 print出自己的第二行信息
  10. 第二个super().say(),运行A类的say()
  11. 第三个self.eat(),根据 __mro__ , 找到的是 B 类实现的eat方法
  12. 第四个super().eat(),根据 __mro__ , 找到的是 B 类实现的eat方法
  13. 第五个C.eat(self)忽略 mro , 找到的是 C 类实现的eat方法

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值