博客
关于我
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中 delimiter 详解
    查看>>
    MYSQL中 find_in_set() 函数用法详解
    查看>>
    MySQL中auto_increment有什么作用?(IT枫斗者)
    查看>>
    MySQL中B+Tree索引原理
    查看>>
    mysql中cast() 和convert()的用法讲解
    查看>>
    mysql中datetime与timestamp类型有什么区别
    查看>>
    MySQL中DQL语言的执行顺序
    查看>>
    mysql中floor函数的作用是什么?
    查看>>
    MySQL中group by 与 order by 一起使用排序问题
    查看>>
    mysql中having的用法
    查看>>
    MySQL中interactive_timeout和wait_timeout的区别
    查看>>
    mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
    查看>>
    mysql中json_extract的使用方法
    查看>>
    mysql中json_extract的使用方法
    查看>>
    mysql中kill掉所有锁表的进程
    查看>>
    mysql中like % %模糊查询
    查看>>
    MySql中mvcc学习记录
    查看>>
    mysql中null和空字符串的区别与问题!
    查看>>
    MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
    查看>>