########################总结################

面向对象回顾

  类:对某一个事物的描述,对一些属性和方法的归类

class 类名:
var=123#类变量 def __init__(self,x,x,x)#实例变量
self.xxx=xxx
self.xxx=xxx
self.xxx=xxx
#实例方法:给对象用的
def method(self):
pass
@staticmethod():--函数
def stsmethod():
pass
@classmethod--方法
def clsmethod(cls):
pass
@property
def age(self):#把一个方法变成属性
retun 10
def __privatemethod(slef):私有方法
pass
类可以互相继承
class Base:#超类 基类
pass
class Person(Base,Base2):#派生类
pass 约束
1.写一个父类,在父类中写出要被约束的方法,
raise NotImplmentedError()
2.写一个抽象类,子类重写抽象类中的抽象方法
from abc import ABCMeta,abstractmethod
class Foo(metclass=ABCMeta):
@abstractmethod
def 抽象方法(self):
pass
反射
getattr(对象,str)
hasattr(对象,str)
setattr(对象,strt,value)
delattr(对象,strt)

2. 明白对象是什么
什么是对象, 什么都是对象.
在编程的世界里. 对象是由类创建.
类名() -> 创建对象, 实例化
此时会默认的调用两个方法 -> __new__()开辟内存 -> __init__()
对象能够执行的方法都写在类中. 对象的属性一般都写在__init__()


对象最主要的意义就是对数据进行封装.

class Stu:

  def __init__(self, name, sno, age):
    self.name = name
    self.sno = sno
    self.age = age


bb = Stu("宝宝", "1", 18)

python 在2.4之前使用的是经典类  2.4之后使用新式类

经典类的mro 树形结构深度优先遍历

从左往右 一条道走到黑

class A:
  pass
class B(A):
  pass
class C(A):
  pass
class D(B,C):
  pass
class E(C,A):
  pass
class F(D,E):
  pass
class G(E):
  pass
class H(G,F):
  pass #加法 merge()
拿第一项和后面每项的第一位比较,如果没有则计算出
如果出现了,此时开始下一项的第一位
头和身体的比较

新式类的mor C3算法
L(H)= H +L(G)+L(F)+GF h+geca+fdbeca =hgfdbeca
L(G)= G +L(E)+E g+eca+e =geca
L(F)= F +L(D)+L(E)+DE f+dbca+eca+de =fdbeca
L(E)= e +l(C)+L(A)+CA e+ca+a+ca =eca
L(D)= D +L(B)+L(C)+BC D+ba+ca+bc =dbca 比到c的时候第二位没有就写上
L(C)= C +L(A)+A ca
L(B)= B +L(A)+A ba
L(A)= A print(H.__mro__)

super() 找MRO顺序的下一个

class Base1:
def chi(self):
print("我是可怜的Base1") class Base2:
def chi(self):
print("我是可怜的Base2") class Base3:
def chi(self):
print("我是可怜的Base3") class Bar(Base1, Base2, Base3):
def chi(self):
print("我是Bar里面的吃1")
# super(类名, self) 从某个类开始找下一个MRO
super(Base2, self).chi() # 此时调用的super. 在Bar调用 -> super表示找MRO里的下一个
# super().chi() # super(Bar, self).chi()
print("我是Bar里面的吃2") b = Bar() # Bar, Base1, Base2, Base3, object
b.chi()
print(Bar.__mro__) ###################结果#################

我是Bar里面的吃1
我是可怜的Base3
我是Bar里面的吃2
(<class '__main__.Bar'>, <class '__main__.Base1'>, <class '__main__.Base2'>, <class '__main__.Base3'>, <class 'object'>)

############一道 面试题###########

# MRO + super 面试题
class Init(object):
def __init__(self, v): #
print("init")
self.val = v class Add2(Init):
def __init__(self, val): #
print("Add2")
super(Add2, self).__init__(val) # Mult
print(self.val)
self.val += 2 class Mult(Init):
def __init__(self, val):
print("Mult")
super(Mult, self).__init__(val) # Haha
self.val *= 5 class HaHa(Init):
def __init__(self, val):
print("哈哈")
super(HaHa, self).__init__(val) # Init
self.val /= 5 class Pro(Add2,Mult,HaHa): #
pass class Incr(Pro): #
def __init__(self, val): #
super(Incr, self).__init__(val) # Add2
self.val += 1 p = Incr(5)
print(p.val)
c=Add2(2)
print(v.cal)

先算mro

L(Incr)=Incr+l(Pro)+Pro  Incr+pro,Add2,Mult,HaHa,init+Pro  结果Incr+pro+Add2,Mult,HaHa,init
L(Pro)=Pro+l(Add2)+l(Mult)+l(HaHa)+Add2+Mult+HaHa #因为Add2,Mult,HaHa继承的都是init
L(Pro)=Pro+Add2,init+Mult,init+HaHa,init+Add2,Mult,HaHa 计算结果:pro,Add2,Mult,HaHa,init # p = Incr(5) # p.val = 8.0
# # Add2
# # Mult
# # 哈哈
# # init
# # 5.0
# # 8.0
# print(p.val)
#
c = Add2(2) # Add2, Init, Object c.val = 2
# Add2
# init
# 2
# 4

python 面向对象(六)MRO C3算法 super的更多相关文章

  1. day19 MRO C3算法 super()

    1. MRO(Method Resolution Order):方法解析顺序,主要用于在多继承时判断调的属性的路径(来自于哪个类). 1.Python语言包含了很多优秀的特性,其中多重继承就是其中之一 ...

  2. MRO C3算法 super的运用

    -------------态度决定成败,无论情况好坏,都要抱着积极的态度,莫让沮丧取代热心.生命可以价值极高,也可以一无是处,随你怎么去选择.# --------------------------- ...

  3. python学习笔记:第20天 多继承、MRO C3算法

    目录 一.多继承 二.旧式类的MRO 三.新式类的MRO 四.super 一.多继承 之前已经学习过了继承,当出现了x是⼀种y的的时候,就可以使⽤继承关系,即"is-a" 关系.在 ...

  4. 面向对象多继承(c3算法)、网络基础和编写网络相关的程序

    一.面向对象多继承(c3算法) a.有多个父类先找左,再找右,如下示例: class A(object): pass class B(object): def f1(self): print('B') ...

  5. 面向对象多继承(C3算法)/网络编程

    https://www.cnblogs.com/aylin/p/5572104.html 一.面向对象多继承(c3算法) a.有多个父类先找左,再找右,如下示例: class A(object): p ...

  6. MRO,C3算法

    1了解python2和python3类的区别 python2在2.4之前使用的是经典类, 2.4之后, 使用的是新式类 class Foo: pass class Foo(object): pass ...

  7. python --- 21 MRO C3算法

    一.python2.2之前用的是   经典类的MRO继承 ①深度递归继承     从左到右 ,一条路走到黑 ②广度继承           一层一层的继承 深度继承时   为   R 1 2 3 4 ...

  8. python中多继承C3算法研究

    在python的面向对象继承问题中,单继承简单易懂,全部接受传承类的属性,并可添加自带属性, 但是,在多继承情况下,会遇到多个被继承者的顺序问题,以及多次继承后查找前几次继承者需求属性时,可能不易发现 ...

  9. 21 MRO C3算法

    三十九 MRO 多继承的继承顺序 一.python2.2之前用的是   经典类的MRO继承 ①深度递归继承     从左到右 ,一条路走到黑 ②广度继承           一层一层的继承 深度继承时 ...

随机推荐

  1. npm、webpack、vue-cli

    Node.js   npm 什么是Node.js  以及npm 简单的来说 Node.js 就是运行在服务端的JavaScript,基于Chrome V8 引擎的. npm 是Node.js 的包管理 ...

  2. Python中的numpy模块解析

    numpy 1.  创建对象 维度(dimensions):轴 轴的个数:秩(rank) Numpy最重要的一个特点就是其N维数组对象(即ndarray) 创建数组最简单的函数就是用array函数: ...

  3. android最最基础简单的保存xml代码

    y偶遇非常基础,我想直接上代码: MainActivity.java: package com.lgqchinese.xmlcreate; import android.support.v7.app. ...

  4. 【BZOJ4033】【HAOI2015】树上染色 树形DP

    题目描述 给你一棵\(n\)个点的树,你要把其中\(k\)个点染成黑色,剩下\(n-k\)个点染成白色.要求黑点两两之间的距离加上白点两两之间距离的和最大.问你最大的和是多少. \(n\leq 200 ...

  5. Java实现一个双向链表的倒置功能

    题目要求:Java实现一个双向链表的倒置功能(1->2->3 变成 3->2->1) 提交:代码.测试用例,希望可以写成一个Java小项目,可以看到单元测试部分 该题目的代码, ...

  6. 【hdu6186】CS Course(前缀后缀异或)

    2017ACM/ICPC广西邀请赛 重现赛1005CS Course 题意 给一个数列a,每次询问去掉第p个的与和.或和,异或和. 题解 预处理前缀和.后缀和即可. 但是当时想都没想就写了个线段树.线 ...

  7. 「CF838B」 Diverging Directions

    B. Diverging Directions 题意 给出一个n个点2n-2条边的有向图.n-1条指向远离根方向的边形成一棵树,还有n-1条从非根节点指向根节点的边. q次操作,1修改第x条边权值为y ...

  8. 【UOJ#177】欧拉回路

    [UOJ#177]欧拉回路 题面 UOJ 题解 首先图不连通就没啥好搞的了. 对于无向图而言,每个点度数为偶数. 对于有向图而言,每个点入度等于出度. 然后就是一本通上有的做法,直接\(dfs\)一遍 ...

  9. 文艺平衡Splay树学习笔记(2)

    本blog会讲一些简单的Splay的应用,包括但不局限于 1. Splay 维护数组下标,支持区间reserve操作,解决区间问题 2. Splay 的启发式合并(按元素多少合并) 3. 线段树+Sp ...

  10. Apache虚拟主机+AD压力测试

    <Directory "/usr/local/awstats/wwwroot"> Options NoneAllowOverride None Order allow, ...