python多继承下的查找顺序-MRO原则演变与C3算法
在python历史版本中的演变史
python2.2之前:
MRO原则:
只有经典类,遵循深度优先(从左到右)原则,
存在的问题:在有重叠的多继承中,违背重写可用原则
解决办法是再设计类的时候不要设计这样有问题的类
python2.2版本:
MRO原则:
经典类:遵循深度优先(从左到右)原则
引入新式类:在深度优先(从左到右)的算法基础之上, 优化了一部分,如果产生重复元素, 会保留最后一个,并且, 更尊重基类出现的先后顺序
新式类存在的问题:无法检测出有问题的继承,
有可能还会违背局部优先的原则
例如:
python2.3-2.7版本:
MRO原则:
经典类:遵循深度优先(从左到右)原则
新式类:C3算法
python3.x之后:MRO原则:
只有新式类:C3算法
C3算法详解:
公式:
L(object) = [ object ]
L(子类(父类1,父类2)) = [ 子类 ] + merge(L(父类1) + L(父类2) + [父类1,父类2])
注意:+ 代表合并列表
mergel算法:
1、第一个列表中的第一个元素如果是后面列表中的首个元素或者在后面列表中不存在,则将这个元素合并到merge函数前面的最终列表中,并删除这个元素
2、如果第一个列表第一个元素不成立,则查看第二个列表首个元素,执行第1步操作
3、如果最终无法把所有元素都归到最终的解析列表中,则报错,说明是错误的继承关系
案列代码:
class D(object):
# pass # L(D(object)) = [D] + merge(L(object), [object])
# = [D] + merge([object], [object])
# = [D, object] + merge([], [])
# = [D, object] # class B(D):
# pass # L(B(D)) = [B] + merge(L(D), [D])
# = [B] + merge([D, object], [D])
# = [B, D] + merge([object], [])
# = [B, D, object] + merge([], [])
# = [B, D, object] # class C(D):
# pass
# L(C(D)) = [C, D, object] # class A(B, C):
# pass
# L(A) = [A] + merge(L(B), L(C), [B, C])
# = [A] + merge([B, D, object], [C, D, object], [B, C])
# = [A, B] + merge([D, object], [C, D, object], [C])
# = [A, B, C] + merge([D, object], [D, object])
# = [A, B, C, D] + merge([object], [object])
# = [A, B, C, D, object] + merge([], [])
# = [A, B, C, D, object]
查看继承顺序的方法
1、import inspect
print(inspect.getmro(类))
2、类.mro()
类.__mro__()
python多继承下的查找顺序-MRO原则演变与C3算法的更多相关文章
- sqlalchemy mark-deleted 和 python 多继承下的方法解析顺序 MRO
sqlalchemy mark-deleted 和 python 多继承下的方法解析顺序 MRO 今天在弄一个 sqlalchemy 的数据库基类的时候,遇到了跟多继承相关的一个小问题,因此顺便看了一 ...
- day 24 面向对象之继承及属性查找顺序
组合 组合:自定义类的对象作为另外一个类的属性 class Teacher: def init(self, name, age): self.name = name self.age = age t1 ...
- 【Windows下DLL查找顺序 】
一.写作初衷 在Windows下单个DLL可能存在多个不同的版本,若不特别指定DLL的绝对路径或使用其他手段指定,在应用程序加载DLL时可能会查找到错误的版本,进而引出各种莫名其妙的问题.本文主要考虑 ...
- super之mro列表牵引出c3算法
目录 一:super的使用 二:super之mro列表牵引出c3算法 三:mro列表总结使用 一:super的使用 class Person(object): def __init__(self, n ...
- python面向编程:类继承、继承案例、单继承下属性查找、super方法
一.类的继承 二.基于继承解决类与类的代码冗余问题 三.在单继承背景下属性的查找 四.super的方法 一.类的继承 1.什么是继承? 在程序中继承是一种新建子类的方法的方式,新创建的类成为子类\派生 ...
- 类和实例属性的查找顺序 mro查找
如果多个类继承父类,然后又被多个类继承这种复杂的问题,可以使用 mro方法 例如: class A: pass class C(D): pass class B(D): pass class A(B, ...
- Windows下DLL查找顺序
目录 第1章说明 2 1.1 查找顺序 2 1.1.1 检查DllCharacteristics字段 3 1.1.2 读取manifset资源 3 1.1.3 读取manifs ...
- 【实测】Python 和 C++ 下字符串查找的速度对比
完整格式链接:https://blog.imakiseki.cf/2022/03/07/techdev/python-cpp-string-find-perf-test/ 背景 最近在备战一场算法竞赛 ...
- Python实现Linux下文件查找
import os, sys def search(curpath, s): L = os.listdir(curpath) #列出当前目录下所有文件 for subpath in L: #遍历当前目 ...
随机推荐
- CentOS 7下限制ip访问
此教程的作用:设置SSH只允许特定用户从特定的IP登录,其它未经允许的用户和IP都不能登录 示例1:只允许192.168.0.222登录192.168.1.81 # vim /etc/hosts.al ...
- Docker二
Docker生成镜像的两种方式 有时候从Docker镜像仓库中下载的镜像不能满足要求,我们可以基于一个基础镜像构建一个自己的镜像 两种方式: 更新镜像:使用docker commit命令 构建镜像:使 ...
- 《精通并发与Netty》学习笔记(12 - 详解NIO (三) SocketChannel、Pipe)
一.SocketChannelJava NIO中的SocketChannel是一个连接到TCP网络套接字的通道.可以通过以下2种方式创建SocketChannel: 打开一个SocketChannel ...
- 最新 浪潮java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.浪潮等10家互联网公司的校招Offer,因为某些自身原因最终选择了浪潮.6.7月主要是做系统复习.项目复盘.LeetCode ...
- tomcat8.5.37设置虚拟目录
之前做的solr和tomcat是放在tomcat的webapps下 solr7.2.1+tomcat8.5.37+jdk8安装配置 现在就是放在其他,通过tomcat的server.xml配置虚拟目录 ...
- 本机sshd服务开启但是其他机器不能登陆
问题现象: 发现本机sshd服务开启但是其他机器不能登陆 查看sshd服务 [root@localhost ~]# systemctl status sshd.service ● sshd.servi ...
- upw,c#,代码实现关闭,重启应用
微软为uwp直接提供了这些API,可以很容易的直接进行调用 关闭 using Windows.ApplicationModel.Core; CoreApplication.Exit(); or usi ...
- 飞腾PC机器与奔腾G645的PC机器以及E5-2630V4虚拟机内存性能简单对比
1. 对比工具 sysbench 2. 对比命令 sysbench --test=memory --memory-total-size=12G --num-threads= run 3 安装方式 #u ...
- java xml解析方式(DOM、SAX、JDOM、DOM4J)
XML值可扩展标记语言,是用来传输和存储数据的. XMl的特定: XMl文档必须包含根元素.该元素是所有其他元素的父元素.XML文档中的元素形成了一颗文档树,树中的每个元素都可存在子元素. 所有XML ...
- IDEA下tomcat启动后 server乱码,Tomcat Catalina Log乱码问题的解决
如果你初接触Idea,一定会遇到控制台乱码的问题,这里和eclipse有点不一样,看如下办法: 乱码的根本原因:Windows系统的cmd是GBK编码的,所以IDEA的下方log输出的部分的编码也是G ...