python多继承mro_理解Python的多继承MRO

什么是MRO

Method Resolution Order , 定义了Python中多继承存在的情况下,解释器查找函数解析的具体顺序

什么是函数解析顺序# 经典继承问题 - 棱形继承

class A:

def who_am_i(self):

print("i am A")

class B:

pass

class C:

def who_am_i(self):

print("i am A")

class D(B, C):

pass

d = D()

d.who_am_i()

# 结果为

i am A

None

经典类(Old-style Class) VS 新式类(New-style- Class)

# MRO算法不一样

# DFS 深度优先算法 BFS 广度优先算法

python 2.1 经典类 ,DFS算法

python 2.2 引入新式类,DFS和BFS算法

python 2.3 经典类与新式类共存,DFS和C3算法

python 3+ 新式类,C3算法

深度优先(DFS)

按照从左往右的顺序深度优先遍历类的继承关系,从而缺点类种函数的调用顺序

1 - 检查当前类中是否有此函数,如果有则直接调用

2 - 检查当前类中第一个父类是否有该函数,如果没有则检查父类的第一个父类是否有该函数,以此递归深度遍历

3 - 如果没有则回溯一层,检查下一个父类里面是否有该函数,并按照2中的方式递归

4 - 已查找过的类不会再查

广度优先(BFS)

按照从左往右的顺序深度优先遍历类的继承关系,从而缺点类种函数的调用顺序

1 - 检查当前类中是否有此函数,如果有则直接调用

2 - 检查当前类中第一个父类是否有该函数,检查当前类中第二个父类是否有该函数

3 - 如果没有则回溯一层,检查第一个父类的父类里面是否有该函数,并按照2中的方式递归

f8305a7e75b3e55c9273e42991bfd4d8.png

模式对比与劣势深度优先(DFS)

正常模式继承关系: A - B - D - C - E

菱形模式继承关系 : A - B - D - C

DFS缺陷:

棱形继承关系下:先查找A,再查找C,但是C是D 的子类,C类中可以重写D类方法,但永远访问不到。

广度优先(BFS)

正常模式继承关系: A - B - C - D - E

菱形模式继承关系 : A - B - C - D

BFS缺陷:

正常模式继承关系下:D类与C类实现同一方法,D类方法被B继承,但B类无此方法,按照BFS算法,去C类查找,找到并返回,但是期待的B(D) 来实现不同。违背了类的单调性

新式类C3算法

新算法与深度遍历算法类试,但是新算法会对深度优先遍历得到的路径进行额外检查。

Python中,每个类都有一个特殊的属性__mro__,它表示了方法解析顺序(Method Resolution Order),即在多继承中方法的查找顺序。__mro__是一个元组,按照从左到右的顺序列出了类的继承顺序。 在经典类的深度遍历中,方法解析顺序是按照继承顺序从左到右进行搜索的。而在Python 2.2的新式类中,方法解析顺序是预先计算的。而在Python 2.3之后的新式类中,采用了C3算法来确定方法解析顺序。C3算法是Python 3唯一支持的方式。 C3算法的目的是解决Python 2.2中方法解析顺序存在的问题。在Python 2.3及以后的版本中,如果存在具有二义性的继承关系,将会产生一个异常,禁止创建这样的类。 所以,如果你想知道一个类的方法解析顺序,你可以查看它的__mro__属性。例如,在Python中执行以下代码: ``` class A: pass class B: pass class C(A, B): pass print(C.__mro__) ``` 将会输出一个元组,按照方法解析顺序列出了C类的继承顺序。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Python的方法解析顺序(MRO)[转]](https://blog.csdn.net/weixin_30756499/article/details/98422260)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值