python摸爬滚打之day20--多继承,MRO和C3算法
1、新式类和经典类
在python2.2之前, 基类如果不写(), 则表示为经典类;
在python2.2之后, 经典类不复存在, 只存在新式类. 如果基类谁都不继承的话, 则默认继承object.
2、MRO----()方法解释顺序
主要用于多继承时判断属性的路径(来自于哪个类).
经典类的MRO算法 ------树形结构的深度优先遍历
原则: 按继承顺序从左子树到右子树, 一条道走到黑.

class A: pass
class B(A): pass
class C(A): pass
class D(B, C): pass
class E: pass
class F(D, E): pass
class G(F, D): pass
class H: pass
class Foo(H, G): pass
# MRO 顺序: H G F D B A C E
经典类MRO顺序
3、新式类的MRO顺序 ----> 遵循C3算法
先由MRO确定一个线性序列, 然后查找路径由线性序列中类的顺序决定, C3算法就是生成这样的一个线性序列.
c3算法的核心是merge算法.
merge原则: 拿前一项的头和后面所有项的身体进行比较, 如果在后面没有出现, 则拿出这个头并划掉出现的所有该元素,前一项继续往后走;
如果在后面项中出现, 则前一项(a)剩余全部跳过, 比较第二项(b)(用第二项(b)的头和后面所有项的身体比较, 有的话继续跳过去, 比较第三项(c)), 啥时候没有出现, 拿出并划掉后继续返回前一项(a)剩下的元素继续比较.
注意: 可以这样查找: C3算法就是把每个环节多个类产生的共同继承留到最后去找.
class A: pass
class B(A): pass
class C(A): pass
class D(B, C): pass
class E(C, A): pass
class Y: pass
class F(D,Y, E): pass
class G(E): pass
class H(G, F): pass # 先拆分 再从下往上合并, 把前一项的头和后面所有项的身体进行比较, 如果后面出现了则直接跳过, 没有的话前一项接着往后走
# S(H) = H + S(G) + S(F) + GF HGFD BYEC A
# S(G) = G + S(E) GECA
# S(F) = F + S(D) + S(Y) + S(E) + DYE FDBYECA
# S(E) = E + S(C) + S(A) + CA ECA
# S(D) = D + S(B) + S(C) + BC DBCA
# S(B) = B + S(A) BA
# S(C) = C + S(A) CA
print(H.mro()) # HGFD BYEC A
新式类Mro顺序
4、super() ----> 执行MRO中的下一个父类方法.
class Foo:
def func1(self):
super().func1() # 找下一个父类 Bar
print("走你2") class Bar:
def func1(self):
print("走你1") class Ku(Foo,Bar):
def func1(self):
super().func1() # 找下一个父类 Foo
print("走你3") k = Ku()
k.func1() # MRO顺序: ku ----> Foo ----> Bar ----> object
super()
5、已经有继承关系了还要用super()继承呢?
因为有时候普通的继承关系是满足不了需求的.
比如: 用父类的方法来完成自己的一部分代码, 这个时候就能用得到super()了.
class Base:
def __init__(self,a,b,c):
self.a = a
self.b = b
self.c = c class Foo(Base):
def __init__(self,a,b,c,d):
super(Foo, self).__init__(a,b,c) # 用父类方法来构造自己的a,b,c, 自己再添加self.d.
self.d = d # 如果用单纯的非super继承很难实现. f = Foo(11,22,33,44)
print(f.a)
print(f.b)
print(f.c)
print(f.d)
super()继承
再比如: 如果继承的多个类中都存在相同的方法, 使用super能很精准地定位到要执行方法的类.
class Animal:
def act(self):
print("动物会动") class Cat(Animal):
def act(self):
print("猫会动") class BosiCat(Cat):
def act(self):
super(Cat, self).act() # 可以很精准地定位到执行cat()类的下一个类的act()方法, 不用super()很难定位精确.
print("波斯猫会动") b = BosiCat().act()
super()继承
python摸爬滚打之day20--多继承,MRO和C3算法的更多相关文章
- python的垃圾回收机制 继承的顺序C3算法
Python垃圾回收 -- 引用计数 -- Python为每个对象维护一个引用计数 -- 当引用计数为0的 代表这个对象为垃圾 -- 标记清除 - ...
- Python的多继承问题-MRO和C3算法
大部分内容转载自C3 线性化算法与 MRO 理解Python中的多继承 Python 中的方法解析顺序(Method Resolution Order, MRO)定义了多继承存在时 Python 解释 ...
- day21 MRO和C3算法
核能来袭 --MRO和C3算法 1. python的多继承 2.python经典类的MRO 3.python新式类的MRO, C3算法 4.super 是什么鬼? 一.python的多继承 在前面的学 ...
- Python之MRO及其C3算法
[<class '__main__.B'>, <class '__main__.A'>, <class 'object'>] (<class '__main_ ...
- python之路--MRO和C3算法
一 . MRO(method resolution order) 多继承的一种方法,一种查找的顺序 在python3 里面是一种新类式MRO 需要用都的是C3算法 class A: pass clas ...
- python之MRO和C3算法
python2类和python3类的区别pyhon2中才分新式类与经典类,python3中统一都是新式类Python 2.x中默认都是经典类,只有显式继承了object才是新式类python 3.x中 ...
- python中的MRO和C3算法
一. 经典类和新式类 1.python多继承 在继承关系中,python子类自动用友父类中除了私有属性外的其他所有内容.python支持多继承.一个类可以拥有多个父类 2.python2和python ...
- python小兵 面向对象继承super和c3算法
python多继承 在前面的学习过程中. 我们已经知道了Python中类与类之间可以有继承关系. 当出现了x是一种y的的时候. 就可以使⽤继承关系. 即"is-a" 关系. 在继承 ...
- python全栈开发day103-python垃圾回收机制、mro和c3算法解析、跨域jsonp\CORS、Content-Type组件
Python垃圾回收 -- 引用计数 -- Python为每个对象维护一个引用计数 -- 当引用计数为0的 代表这个对象为垃圾 -- 标记清除 -- 解决孤立的循环引用 -- 标记根节点和可达对象 - ...
随机推荐
- MySQL技术内幕读书笔记(一)——Mysql体系结构和存储引擎
目录 MySQL体系结构和存储引擎 定义数据库和实例 MYSQL体系结构 MYSQL存储引擎 MySQL体系结构和存储引擎 定义数据库和实例 数据库:物理操作系统文件或者其他形式文件类型的结合.在MY ...
- 史上最简单的 SpringCloud 教程 | 终章
https://blog.csdn.net/forezp/article/details/70148833转载请标明出处:http://blog.csdn.net/forezp/article/det ...
- k8s dev
0. install golang 1.9.1 https://golang.org/doc/install 1. development.md https://github.com/kubernet ...
- .net core Dapper for MySql
Dapper 语法比较简单,效率也比较快,速度接近IDataReader 甚至读取数据超过了DataTable,建议在实际项目可以结合EntityFramework Core 一起使用. 一.创建My ...
- 值得从PHP转向JavaScript
1.掌握一门语言而成为爆栈工程师确实诱惑力极大 2.JavaScript 代码的语义性比 PHP 更强一些,当然语言整体特性也复杂不少,学习成本是更高的 3.JSON原生:配合MongoDB的话,从头 ...
- Android全面屏适配
什么是全面屏 概念 很多人可能把全面屏跟曲面屏混淆,其实这是两个不同的概念. 一般手机的屏幕纵横比为16:9,如1080x1920.1440x2560等,其比值为1.777777……,全面屏手机出现之 ...
- Houdini技术体系 基础管线(四) :Houdini驱动的UE4植被系统 下篇
背景 在上篇中,实现了使用Houdini在UE4里根据地形过程生成植被的最基本的原型.并且支持把植被在UE4里Bake成使用的HierarchicalInstancedStaticMeshCompon ...
- Houdini技术体系 基础管线(四) :Houdini驱动的UE4植被系统 上篇
背景 之前在<Houdini技术体系 过程化地形系统(一):Far Cry5的植被系统分析>一文中已经对AAA游戏中过程化植被的需求有了一定的定义,后续工作就是如何用Houdini开发功能 ...
- JavaScript 运行机制详解:Event Loop
参考地址:http://www.ruanyifeng.com/blog/2014/10/event-loop.html 一.为什么JavaScript是单线程? JavaScript语言的一大特点就是 ...
- 从0移植uboot(五) _实现串口输出
串口作为一种非常简单的通信方式,才是嵌入式系统调试的王道,通过设置串口输出,我们可以将程序运行的情况直接通过串口线输出到屏幕上,对于这种异常重要的功能,uboot原生就提供了支持,但为此我们需要做一些 ...