博客
关于我
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/

    你可能感兴趣的文章
    oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>
    Oracle10g EM乱码之快速解决
    查看>>
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>