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的 代表这个对象为垃圾 -- 标记清除 -- 解决孤立的循环引用 -- 标记根节点和可达对象 - ...
随机推荐
- 18.翻译系列:EF 6 Code-First 中的Seed Data(种子数据或原始测试数据)【EF 6 Code-First系列】
原文链接:https://www.entityframeworktutorial.net/code-first/seed-database-in-code-first.aspx EF 6 Code-F ...
- 设置 WPF 的内容支持触摸直接滚动
在滚动内容上设置属性 ScrollViewer.PanningMode 的值即可. 另外可重写 OnManipulationBoundaryFeedback 方法来替换系统默认的滚动到最上最下时触发的 ...
- .NET Core +NuGet 创建打包发布自己的类库包
1. 创建类库项目 你可以使用现有的 .NET 类库项目用于要打包的代码,或者创建一个简单的项目,.NET CORE 2.1 项目的 类库如下所示: NugetDemo.class using Sys ...
- 不得不看,只有专家才知道的17个SQL查询提速秘诀!
不得不看,只有专家才知道的17个SQL查询提速秘诀! 原创 2018-01-23 布加迪编译 51CTO技术栈 “ 除非你遵循本文介绍的这些技巧,否则很容易编写出减慢查询速度或锁死数据库的数据库代码. ...
- js实现根据文本下标位置添加特殊标识
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- C语言 · 还款计算
标题: 还款计算 银行贷款的等额本息还款方法是: 每月还固定的金额,在约定的期数内正好还完(最后一个月可能会有微小的零头出入). 比如说小明在银行贷款1万元.贷款年化利率为5%,贷款期限为24个月. ...
- RSA加密算法详解(一)
如果你问我,哪一种算法最重要? 我可能会回答"公钥加密算法". 因为它是计算机通信安全的基石,保证了加密数据不会被破解.你可以想象一下,信用卡交易被破解的后果. 进入正题之前,我先 ...
- centos7配置固定ip
查看本机gateway netstat -rn (以0.0.0.0开始的行的gateway是默认网关) vi /etc/sysconfig/network-scripts/ifcfg-enp0s3 T ...
- 微信小程序使用npm安装包
小程序现在支持直接通过npm安装包了,点击这里了解更多. 记录一下我自己的安装步骤及安装过程中遇到的一些问题.希望能够帮助到正在阅读此篇文章的你~ 我就直接通过在项目根目录安装miniprogram- ...
- 服务器返回:type":"Buffer","data":
接口中返回"type":"Buffer","data":[32,232,175,183,233,151,174,229,177,177,23 ...