博客
关于我
Pyhton 类继承之 self.method() 的方法解析顺序
阅读量:708 次
发布时间:2019-03-21

本文共 1092 字,大约阅读时间需要 3 分钟。

对于如下的继承关系,Class MyClass 的对象调用的方法 display 在 Class Base 和 Class B 中都存在,实际调用的是哪一个?

可见,类的继承关系构建如下:

Base   /  \  A    B/MyClass

分析类的MRO(Method Resolution Order)可以更清晰地理解问题。当分别查看obj.display()的执行流程时,结果表明最终执行的是Class Base的display方法,而不是Class B的display方法。具体分析如下:

  • 类继承关系解析

    • MyClass直接继承自A和B。
    • 但是,根据MRO输出,MyClass的MRO顺序被确定为:[<class 'main.MyClass'>, <class 'main.A'>, <class 'main.Base'>, <class 'main.B'>, <type 'object'>]。
    • 这表明,在Python中,MyClass继承自A和B的同时,Base类在A和B的继承链中存在。这可能是因为Base类同时是A和B的基类,或者是通过多个中间类间接继承而来的。
  • display方法的查找规则

    • 在Python中,方法调用的查找遵循以下规则:
      • 首先查找当前类的方法。
      • 如果找不到,再沿着继承链向上查找。
      • 如果在基类中找到方法,且该方法存在于基类中,那么基类的方法会优先被调用。
    • 在本例中,尽管B类具有自己的display方法,却未被调用,因为在MRO中,Base类的display方法被检查并优先于B类的方法被使用。
  • 实际调用的原因

    • 当调用MyClass的display方法时,Python首先查找MyClass的display方法。
    • 如果不存在,则查找A类中的display方法。
      • 在本例中,A类并没有定义display方法,因此继续查找。
    • 最终,沿着MRO继续查找,Base类的display方法存在并被调用。
    • 因此,尽管B类也有display方法,Base类的方法会被优先调用。
  • 结论:在上述继承关系中,MyClass对象调用display方法时,实际调用的是Class Base中的display方法,而不是Class B中的display方法。这是因为Python的MRO机制将Base类作为B类和A类的共同基类,并在查找过程中优先考虑Base类的方法。

    这个现象表明,在多层继承关系中,理解类的MRO非常重要,因为它直接影响方法的查找和调用结果。虽然B类也有display方法,但Base类的方法会被优先选用,除非在更具体的子类中重新定义了该方法。

    转载地址:http://dgwrz.baihongyu.com/

    你可能感兴趣的文章
    mysql 存储过程每隔一段时间执行一次
    查看>>
    mysql 存在update不存在insert
    查看>>
    Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
    查看>>
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    MySQL 导出数据
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>