一.今日主要内容

1.了解python2和python3类的区别
python2在2.2之前使用的是经典类,2.2之后,使用的是新式类
class Foo:
pass
class Foo(object):
pass MRO:method resolution order 方法的查找顺序 class Base:
pass
class Base1:
def chi():
pass
class Bar(Base,Base1):
pass b=Bar() #Bar => Base=>Base1
b.chi() 2.经典类的MRO (树形结构的深度优先递归遍历,这个需要了解)=>树形结构的遍历 3.新式类的MRO C3算法(笔试或者面试别人的算法)(难点,重点)(python没有用过广度优先)
(1)拆分
(2)合并 用头和身体比较
4.super() 找MRO顺序的下一个 #只有讲完MRO才能讲
5.一道面试题

二.今日内容大纲:

1.深度递归

2.MRO_C3

3.super

三.今日内容详解:

1.深度递归

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 I:
pass
class J(B, C):
pass
class K(A):
pass
class H(I, J, K):
pass
class Foo(H, G):
pass

结果:

#FOO=>H=>I=>J=>B=>A=>C=>K=>G=>F=>D=>E

2.MRO_C3

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 M:
pass
class N(M):
pass
class P(E, A):
pass
class X:
pass
class Q(P, N, X):
pass
class G(Q, F):
pass
class H(G, F):
pass '''
L(H) = H + L(G) + L(F) + GF # HGQPFDBECANMX L(G) = G + L(Q) + L(F) + QF # GQPFDBECANMX
L(Q) = Q + L(P) + L(N) + X + PNX # QPECANMX (Q+PECA+NM+X+PNX)
L(P) = P + L(E) + A + EA # PECA
L(E) = E + L(C) + A + CA # ECA
L(C) = C + A + A # CA
L(N) = N + M # NM L(F) = F + L(D) + L(E) + DE # FDBECA
L(D) = D + L(B) + L(C) + BC # DBCA '''
'''
求H的MRO
设求MRO的算法是L
L(H) = H + L(G) + L(F) + GF
L(G) = G + L(E) + E
L(E) = E + L(C) + L(A) + CA
L(C) = C + L(A) + A
L(A) = A
L(F) = F + L(D) + L(E) + DE
L(D) = D + L(B) + L(C) + BC
L(B) = B + L(A) + A # 加法:merge(), 拿第一项的第一位和 后面每项的除了第一位比较. 如果没有出现, 则该位元素算出
如果出现了. 此时开始下一项的第一位继续和后面每一项的除了第一位比较: 用头和后面身体比较 L(H) = H + L(G) + L(F) + GF # ECA + DBECA = HGFDBECAO
L(G) = G + L(E) + E # GECA
L(E) = E + L(C) + L(A) + CA # ECA
L(C) = C + L(A) + A # CA
L(A) = A
L(F) = F + L(D) + L(E) + DE # FDBECA
L(D) = D + L(B) + L(C) + BC # DBCA
L(B) = B + A + A # BA
'''
print(H.__mro__)

3.super

(1)

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里面的吃')
#super(类名,self) #从某个类开始找下一个MRO
super(Bar,self).chi() #此时调用的super,在Bar调用=>super表示找MRO里的下一个
#super(Base1,self).chi()
#super(Base2,self).chi() b = Bar() #顺序: Bar, Base1, Base2, Base3, object
b.chi()
print(Bar.__mro__)

(2)

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

(3)

# MRO + super ⾯试题
class Init(object): #在下面对应子类和父类都可以
def __init__(self,v): #在这里注意解题的标记
print('init') #HaHa
self.val=v
class Add2(Init):
def __init__(self,val):
print('Add2')
super(Add2, self).__init__(val) #Pro
print(self.val)
self.val+=2
class Mult(Init):
def __init__(self,val):
print('Mult')
super(Mult,self).__init__(val) #Add2
self.val*=5
class HaHa(Init):
def __init__(self,val):
print('哈哈')
super(HaHa,self).__init__( val) #Mult
self.val/=5
class Pro(Add2,Mult,HaHa): #Incr
pass
class Incr(Pro): # incr->pro->add2->Mult->HaHa->init
def __init__(self,val):
super(Incr,self).__init__(val) #Add2
self.val+=1
# print(Incr.__mro__) p=Incr(5)
print(p.val)
# Incr Pro Add2 Mult HaHa Init
# p = Incr(5) # p.val = 8.0
'''结果:
# # Add2
# # Mult
# # 哈哈
# # init
# # 5.0
# # 8.0
'''
p=Add2(2)
print(p.val)
# Add2, Init, Object c.val = 2
# Add2
# init
#
# ''' MRO: method resolution order #方法查找顺序
Incr,Pro,Add2,Mult,HaHa,Init,Object '''

巨蟒python全栈开发-第21天 继承的更多相关文章

  1. 巨蟒python全栈开发linux之centos3

    1.作业讲解 (1)递归创建文件夹/tmp/oldboy/python/{alex,wusir,nvshen,xiaofeng} 下面中的路径没有必要换,在哪里创建都行,根目录下或者tmp目录下或者其 ...

  2. 巨蟒python全栈开发linux之centos1

    1.linux服务器介绍 2.linux介绍 3.linux命令学习 linux默认有一个超级用户root,就是linux的皇帝 注意:我的用户名是s18,密码是centos 我们输入密码,点击解锁( ...

  3. 巨蟒python全栈开发-第13天 内置函数 匿名函数lambda

    一.今日内容总览 1.内置函数(1):并不是每一个内置函数都是那么常用 上菜:内置函数部分//思维导图:https://www.processon.com/view/link/5b4ee15be4b0 ...

  4. 巨蟒python全栈开发-第20天 核能来袭-约束 异常处理 MD5 日志处理

    一.今日主要内容 1.类的约束(对下面人的代码进行限制;项目经理的必备技能,要想走的长远) (1)写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError(重点) (2)抽象 ...

  5. 巨蟒python全栈开发-第22天 内置常用模块1

    一.今日主要内容 1.简单了解模块 你写的每一个py文件都是一个模块 数据结构(队列,栈(重点)) 还有一些我们一直在使用的模块 buildins 内置模块.print,input random 主要 ...

  6. 巨蟒python全栈开发linux之centos6

    1.nginx复习 .nginx是什么 nginx是支持反向代理,负载均衡,且可以实现web服务器的软件 在129服务器中查看,我们使用的是淘宝提供的tengine,也是一种nginx服务器 我们下载 ...

  7. 巨蟒python全栈开发django5:组件&&CBV&FBV&&装饰器&&ORM增删改查

    内容回顾: 补充反向解析 Html:{% url ‘别名’ 参数 %} Views:reverse(‘别名’,args=(参数,)) 模板渲染 变量 {{ 变量名 }} 逻辑相关 {% %} 过滤器: ...

  8. 巨蟒python全栈开发-第11阶段 ansible_project3

    今日大纲: 1.用户创建 2.前端优化 3.用户编辑 4.用户删除 5.ansible api介绍 1.用户创建 新建一个user_create.html的页面 <form class=&quo ...

  9. 巨蟒python全栈开发-第11阶段 ansible_project2

    一个NB的网站: https://www.toolfk.com/ CDN:将用户的需求送到最近的节点:内容分发网络 有些是专门做CDN的工具 常用的markdown是需要知道的,短信有字数限制. we ...

随机推荐

  1. Atitit. 脚本语言的断点单步调试的设计与实现 attialx 总结 php 参照java

    Atitit. 脚本语言的断点单步调试的设计与实现 attialx 总结 php 参照java 1. 断点的实现:手动断点 die和exit是等价的 1 2. 变量表的实现 1 3. print_r( ...

  2. mysql数据库分库备份脚本

    mysql数据库分库备份脚本 版本1 for dbname in `mysql -uroot -poldboy123 -e "show databases;" |grep -Evi ...

  3. JS高程3:错误处理和调试

    浏览器打开控制台的快捷键 Ctrl+shift+I try-catch语句 语法 try{ // 可能会导致错误的代码 } catch(error){ // 在错误发生时怎么处理 } 可以自定义错误信 ...

  4. h5-文本框

    h5-文本框 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  5. django中使用POST方法报错 URL via POST, but the URL doesn't end in a slash

    该方式是因为URL路径没有使用slash(斜线"/")结尾造成的. 因此在使用POST的JavaScript函数的路径参数中,路径URL必须使用/结尾.

  6. NerdTree 学习

    http://www.jianshu.com/p/eXMxGx--------------来自大神到博客 到现在为止我仍然不能设置<F2>开启和隐藏目录树.sangxin.

  7. js测试

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. Mysql下Union注入Bypass安全狗过程

    文章转载于:http://www.0aa.me/index.php/archives/95/ 一次众测发现个注入,然后有安全狗就顺带看了下安全狗. 先fuzz看看安全狗拦截什么关键词union sel ...

  9. Codeforces Round #256 (Div. 2) C. Painting Fence(分治贪心)

    题目链接:http://codeforces.com/problemset/problem/448/C C. Painting Fence time limit per test 1 second m ...

  10. jquery仿jquery mobile的select控件效果

    不说废话.直接上代码 //仿jQuery mobile Select控件 //使用方法box为容器id,_id指控件id,selectvalue为选中值,Value为当前值 function Sele ...