C3算法 和 super
一. Python的继承 多继承
子类继承父类.
继承是为了节省开发时间.提高开发效率 代码得到了重(chong)用 一个类可以拥有多个父类
lass shen_xian: # 定义一个神仙类
def fei(self): # 神仙类有一个方法 可以飞
print('神仙都会飞')
class Monkey: # 定义一个猴子类
def chitao(self): # 猴子有一个方法 可以吃桃子
print('猴子喜欢吃桃')
class SunWuKong(Monkey,shen_xian): # 对象继承猴子和神仙的类型
pass
sxz = SunWuKong() # 实例化一个孙悟空对象
sxz.chitao() # 会吃桃子
sxz.fei() # 会飞
多继承用起来简单 但是存在一个问题 当父类中出现重名方法时 就涉及到查找父类方法中的问题 也即MRO(method resolution order)
二. 经典类的MRO
在Python2中存在两种类
经典类 : 在Python 2.2 之前 一直使用的是 经典类
新式类 : 在2.2之后 出现了新式类 特点是 基类的根是object
Python 3
只有新式类 如果基类谁都不继承 那么会默认继承object
经典类的MRO 深度优先遍历 例如 快递员送鸡蛋 :

肯定是按照123456顺序来送 即每次都是最左边 找完撤回到分叉口继续往里找(从左往右,一条道跑到黑,然后撤回继续一条道跑到黑) 即深度优先遍历 如果 142356 就是广度优先遍历
三. 新式类的MRO, C3(重点, 难点) 可以通过 类名.__mro__ 获取到类的mro信息
即print(类名.__mro__) 就可以获取到
Python中的新式类的mro都是用 c3算法来完成的
笔试的时候肯定会考
新式类中摒弃了(部分). C3算法
如果继承关系没有菱形继承(深度优先)
如果有菱形:使用C3算法来计算MRO
三. super
super()可以执行 mro中的下一个父类的方法 通常super()有两个使用的地方 :
1 . 可以访问父类的构造方法
2 . 当子类方法想调用父类(mro)中的方法
先看第一种
class Foo:
def __init__(self,a,b,c):
self.a = a
self.b = b
self.c = c
class Bar(Foo):
def __init__(self,a,b,c,d):
super().__init__(a,b,c)
self.d = d
b = Bar(1,2,3,4)
print(b.__dict__) # {'a': 1, 'b': 2, 'c': 3, 'd': 4}
这样就方便了子类 不需要写那么多了
第二种
class Foo:
def func1(self):
super().func1() # 此时找的是mro顺序中下一个类的func1()方法 实际到这就会报错 根本不会运行
# 因为 Foo 中没有func1方法 继承的obj中也没有func1()方法
print('我的老家,就住在这个屯')
class Bar:
def func(self):
print('你的老家,不在这个屯')
class Ku(Foo,Bar):
def func1(self):
super().func1()
print('它的老家,不知道在哪个屯')
k = Ku() # 先看mro Ku , Foo, Bar ,object
k.func1() k2 = Foo() # 此时的mro Foo , object 都没有func1 因此会报错 如果这样写一开始就会报错 就不会运行到这才报错
k2.func1()
五. 一道面试题
# mro + super 面试题
class Init:
def __init__(self,v):
print('init')
self.val = v
class Add2(Init):
def __init__(self,val):
print('Add2')
super(Add2,self).__init__(val)
print(self.val)
self.val += 2
class Mult(Init):
def __init__(self,val):
print('Mult')
super(Mult,self).__init__(val)
self.val *= 5
class HaHa(Init):
def __init__(self,val):
print('哈哈')
super(HaHa,self).__init__(val)
self.val /= 5
class Pro(Add2,Mult,HaHa):
pass
class Incr(Pro):
def __init__(self, val):
super(Incr, self).__init__(val)
self.val += 1
p = Incr(5)
print(p.val)
c = Add2(2)
print(c.val)
结论 : 不管super()写在哪. 在哪执行,一定先找到mro列表.根据mro列表的顺序往下找 否则都是错的.
C3算法 和 super的更多相关文章
- MRO和C3算法
本节主要内容: 1.python多继承 2.python经典类的MRO 3.python新式类的MRO,C3算法 4.super() 一.python多继承 在python中类与类之间可以有继承关系, ...
- day21 MRO和C3算法
核能来袭 --MRO和C3算法 1. python的多继承 2.python经典类的MRO 3.python新式类的MRO, C3算法 4.super 是什么鬼? 一.python的多继承 在前面的学 ...
- python学习 day20 (3月27日)----(单继承多继承c3算法)
继承: 提高代码的重用性,减少了代码的冗余 这两个写法是一样的 Wa('青蛙').walk() #青蛙 can walk wa = Wa('青蛙') wa.walk() #青蛙 can walk 1. ...
- MRO C3算法 super的运用
-------------态度决定成败,无论情况好坏,都要抱着积极的态度,莫让沮丧取代热心.生命可以价值极高,也可以一无是处,随你怎么去选择.# --------------------------- ...
- python 面向对象(六)MRO C3算法 super
########################总结################ 面向对象回顾 类:对某一个事物的描述,对一些属性和方法的归类 class 类名: var=123#类变量 def ...
- day19 MRO C3算法 super()
1. MRO(Method Resolution Order):方法解析顺序,主要用于在多继承时判断调的属性的路径(来自于哪个类). 1.Python语言包含了很多优秀的特性,其中多重继承就是其中之一 ...
- super之mro列表牵引出c3算法
目录 一:super的使用 二:super之mro列表牵引出c3算法 三:mro列表总结使用 一:super的使用 class Person(object): def __init__(self, n ...
- python小兵 面向对象继承super和c3算法
python多继承 在前面的学习过程中. 我们已经知道了Python中类与类之间可以有继承关系. 当出现了x是一种y的的时候. 就可以使⽤继承关系. 即"is-a" 关系. 在继承 ...
- 手推C3算法
C3算法规则 -- 每一个类的继承顺序都是从基类向子类看 -- 形成一个指向关系的顺序[当前类] + [父类的继承顺序] -- 进行一个提取 -- 如果一个类出现从左到右的第一个顺序上,并且没有出现在 ...
随机推荐
- Centos彻底完全删除已安装软件的办法
1.查询是否安装了软件 rpm -qa | grep -i 软件名 rpm -qa | grep php 2.删除已安装的软件包 根据第一步显示的软件包名,一个个删除 sudo rpm -e -- 包 ...
- Linux 控制台/终端/tty/shell
一.简介 使用linux已经有一段时间,却一直弄不明白这几个概念之间的区别.这些概念本身有着非常浓厚的历史气息,随着时代的发展,他们的含义也在发生改变,它们有些已经失去了最初的含义,但是它们的名字却被 ...
- Luogu U15118 萨塔尼亚的期末考试(fail)
感觉...昨天是真的傻... 题意 T个询问,每个询问给一个n,求 $ \frac{\sum_{n}^{i = 1}Fib_{i} * i}{n * (n + 1) / 2} $ Fib是斐波那契数列 ...
- ubuntu16.04.2安装tftp服务器
1.安装 $ apt-get install tftp-hpa tftpd-hpa tftp-hpa是客户端 tftpd-hpa是服务器 2.创建目录 $ mkdir /tftpboot 这是创建tf ...
- CodeForces 384E Propagating tree (线段树+dfs)
题意:题意很简单么,给定n个点,m个询问的无向树(1为根),每个点的权值,有两种操作, 第一种:1 x v,表示把 x 结点加上v,然后把 x 的的子结点加上 -v,再把 x 的子结点的子结点加上 - ...
- 国内物联网平台(5):机智云IoT物联网云服务平台及智能硬件自助开发平台
国内物联网平台(5)——机智云IoT物联网云服务平台及智能硬件自助开发平台 马智 平台定位 机智云平台是致力于物联网.智能硬件云服务的开放平台.平台提供了从定义产品.设备端开发调试.应用开发.产测.运 ...
- 水平居中的那些事之解决jqpagination分页插件无法居中的问题
固定宽度的元素水平居中只需要 margin-left:auto: margin-right:auto; 换成 margin:0 auto; 也是一样的 今天给我用的jqPagination分页插件实现 ...
- 【转】C# 中的委托和事件(详解)
源地址:http://www.cnblogs.com/SkySoot/archive/2012/04/05/2433639.html
- CF70D(动态凸包)
CF70D(动态凸包) 给出q(<=1e5)个询问,每次在加上一个点,维护凸包,或者询问某个点是否在凸包内(在边上也算). 听说可以用cdq做--但是并不会.我等蒟蒻只会用平衡树做. 首先,假设 ...
- cenos php执行pdf2swf 配置环境
1.第一步:安装xpdf语言包 1.mkdir –p /usr/share/xpdf 2.cd /usr/share/xpdf/ 3.下载中文支持及字体库wget ftp://ftp.foolabs. ...