python_day_19

今日主要内容:

  • 1.抽象类,接口类
  • 2.多态
  • 3.封装

1.抽象类,接口类

python 没有接口这个概念
接口类,抽象类: 制定一个规范. 举个栗子:
你的项目经理提一个需求,让你做一个支付功能.
第一版:
class Alipay:
def __init__(self,money):
self.money = money def pay(self):
print('使用支付宝支付了%s' %self.money) class Jdpay:
def __init__(self, money):
self.money = money def pay(self):
print('使用京东支付了%s' % self.money) a1 = Alipay(200)
a1.pay() j1 = Jdpay(100)
j1.pay()

经理看了,然后让你改进,让你支付的方式一样

第二版:

class Alipay:
def __init__(self,money):
self.money = money def pay(self):
print('使用支付宝支付了%s' %self.money) class Jdpay:
def __init__(self, money):
self.money = money def pay(self):
print('使用京东支付了%s' % self.money) def pay(obj):
obj.pay() a1 = Alipay(200)
j1 = Jdpay(100)
pay(a1) # 归一化设计
pay(j1)

第三版,野生程序员来了.......要增加一个微信支付的功能.
class Alipay:
def __init__(self,money):
self.money = money def pay(self):
print('使用支付宝支付了%s' %self.money) class Jdpay:
def __init__(self, money):
self.money = money def pay(self):
print('使用京东支付了%s' % self.money) class Wechatpay: def __init__(self,money):
self.money = money def weixinpay(self):
print('使用微信支付了%s' % self.money) def pay(obj):
obj.pay() a1 = Alipay(200)
j1 = Jdpay(100)
pay(a1) # 归一化设计
pay(j1) w1 = Wechatpay(300)
w1.weixinpay()

经理看了觉得很乱,打回去重新修改,制定规则,抽象类,接口类
第四版:
from abc import ABCMeta,abstractmethod

class Payment(metaclass=ABCMeta):  # 抽象类(接口类):
@abstractmethod
def pay(self): pass # 制定了一个规范 class Alipay(Payment):
def __init__(self,money):
self.money = money def pay(self):
print('使用支付宝支付了%s' %self.money) class Jdpay(Payment):
def __init__(self, money):
self.money = money def pay(self):
print('使用京东支付了%s' % self.money) class Wechatpay(Payment): def __init__(self,money):
self.money = money def pay(self):
print('使用微信支付了%s' % self.money) def pay(obj):
obj.pay()
w1 = Wechatpay(200)
a1 = Alipay(200)
j1 = Jdpay(100)
pay(a1) # 归一化设计
pay(j1)
pay(w1)

2.多态.

python面向对象的三大特征之一:
多态: python处处是多态.

python:弱类型语言
python 不管什么类型,传入函数,封装到对象中都可以.
python的鸭子类型.
鸭子类型 : 看着像鸭子,他就是鸭子.
以下这些类 都互称为鸭子.
class Str:
def index(self):
pass class List:
def abc(self):
pass class Tuple:
def rrr(self):
pass
3.封装
广义的封装: 实例化一个对象,给对象空间封装一些属性.
狭义的封装: 私有制.
私有成员:私有静态字段,私有方法,私有对象属性
私有静态字段
class B:
__money = 100000 class A(B):
name = 'alex'
__age = 1000 def func(self):
print(self.__age)
print(A.__age) # 对于私有静态字段,类的内部可以访问.
print('func....')
def func1(self):
print(self.__money)
print(A.__money)
a1 = A()
print(a1.name)
print(A.name) print(a1.__age) # 实例化对象不能访问私有静态字段
print(A.__age) # 类名不能访问私有静态字段
对于私有静态字段,类的外部不能访问. a1.func() #对于私有静态字段,类的内部可以访问. a1.func1() #对于私有静态字段来说,只能在本类中内部访问,类的外部,派生类均不可访问. #可以访问,但是工作中千万不要用.
print(A._A__age)
print(A.__dict__) #私有方法 class B:
__money = 100000
def __f1(self):
print('B') class A(B):
name = 'alex' def __func(self):
print('func....') def func1(self):
# self.__func() # 类的内部可以访问
self.__f1()
a1 = A()
a1.__func() # 类外部不能访问
a1.func1() # 类的内部可以访问
a1.func1() # 类的派生类也不能访问.

私有对象属性同私有方法和私有静态字段,类外部不能访问,类的内部可以访问,类的派生类也不能访问.

补充一个面试题:
3,下面代码执行结果是什么?为什么?
class Parent:
def func(self):
print('in Parent func') def __init__(self):
self.func() class Son(Parent):
def func(self):
print('in Son func') son1 = Son()

流程图;

结果图;

原因:

因为Son(),是实例化过程,然后自动执行__init__函数,Son类里没有,去父类里找,然后执行父类的__init__方法,执行func方法,先从自己的类中找,有func,执行func,
打印in Son func 补充知识点:
MRO-C算法-python多继承原理
class H:

    def bar(self):
print('F.bar')
class G(H): def bar(self):
print('F.bar')
class F(H): def bar(self):
print('F.bar')
class E(G): def bar(self):
print('E.bar') class D(F): def bar(self):
print('D.bar') class C(E):
def bar(self):
print('C.bar') class B(D): def bar(self):
print('B.bar') class A(B, C, D): def bar(self):
print('A.bar') a = A()
print(A.mro())

流程图;

执行过程:

A(B,C,D)

首先找到A继承的三个类的深度继承顺序,放到一个列表中
L[B] = [B,D,F,H] #B往上面的继承顺序
L[C] = [C,E,G,H] #C往上面的继承顺序
L[D] = [D,F,H] #D往上面的继承顺序

第二步:A自己的广度,第一层
L[A] = [B,C,D]

每个列表的第一个元素为头部,从第一个列表的头部开始找,找其他列表中尾部是否含有
这个类名,如果没有,提取出来放到一个列表中,如果有,找下一个列表的头部,循环下去
只要提取来一个,我们就从第一个列表的头部接着重复上面的操作.
1 [B,D,F,H] [C,E,G,H] [D,F,H] [B,C,D]
2 [D,F,H] [C,E,G,H] [D,F,H] [C,D] #提取了头部的B,然后将其他列表头部的B删除,并将B放到list中
3 [D,F,H] [E,G,H] [D,F,H] [D] #因为第一个列表的D在其他列表的尾部存在,所以跳过D,然后找第二个列表的头部C,提取了头部的C,然后将其他列表头部的B删除,并将B放到list中

.......

4 [H] [H] [H] []

list = [A,B,C,D,F,E,G,H,O]


2018-07-26  17:41:25

python全栈开发-面向对象-进阶2的更多相关文章

  1. python全栈开发-面向对象-进阶

    python_day_18 1,面向对象的三大特性是什么?继承,多态,封装2,什么是面向对象的新式类?什么是经典类?凡是继承object类都是新式类.凡是不继承object类都是经典类.3,面向对象为 ...

  2. python全栈开发-面向对象-初识

    python_16_day 函数总结: https://www.processon.com/view/link/5b718274e4b0555b39e1055f 面向过程的程序设计的核心是过程(流水线 ...

  3. python全栈开发-面向对象-初识2

    python_17_day 今日主要内容: 1.类空间,对象空间,查询顺序. 2.组合. 1.类空间,对象空间,查询顺序. class Person: animal = '高级动物' soul = ' ...

  4. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  5. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

  6. python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)

    昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...

  7. Python全栈开发相关课程

    Python全栈开发 Python入门 Python安装 Pycharm安装.激活.使用 Python基础 Python语法 Python数据类型 Python进阶 面向对象 网络编程 并发编程 数据 ...

  8. Python 全栈开发【第0篇】:目录

    Python 全栈开发[第0篇]:目录   第一阶段:Python 开发入门 Python 全栈开发[第一篇]:计算机原理&Linux系统入门 Python 全栈开发[第二篇]:Python基 ...

  9. python全栈开发中级班全程笔记(第二模块、第四章)(常用模块导入)

    python全栈开发笔记第二模块 第四章 :常用模块(第二部分)     一.os 模块的 详解 1.os.getcwd()    :得到当前工作目录,即当前python解释器所在目录路径 impor ...

随机推荐

  1. canvas二三事之签名板与视频绘制

    今天,不知道怎么的就点开了语雀,然后就看到了<HTML5 Canvas 教程>,开始了canvas的研究(学习)之旅. 首先,想到的第一个东西就是签名板,上代码: <canvas i ...

  2. Ubuntu安装docker笔记

    前言   根据参考文档简单记录Ubuntu系统安装docker的步骤 系统版本 panzi@ubuntu:~$ cat /etc/issue Ubuntu 16.04.5 LTS \n \l 移除旧版 ...

  3. Convolution1D与Convolution2D区别

    以下是Convolution1D的例子: # apply a convolution 1d of length 3 to a sequence with 10 timesteps, # with 64 ...

  4. 初始化列表initializer_list

    初始化列表定义在<initializer_list>,初始化列表简化了参数数量可变的函数的编写,初始化列表的所有的元素都应该是同一种数据类型 由于定义了列表中允许的类型,所以初始化列表是安 ...

  5. linux下mysql忘记密码怎么办

    前言 今天在服务器安装mysql之后,登录发现密码错误,但是我没有设置密码呀,最后百度之后得知,mysql在5.7版本之后会自动创建一个初始密码. 报错如下: [root@mytestlnx02 ~] ...

  6. 【题解】洛谷P1080 [NOIP2012TG] 国王游戏(贪心+高精度)

    次元传送门::洛谷P1080 思路 我们模拟一下只有两个大臣的时候发现 当a1​∗b1​<a2​∗b2​是ans1<ans2 所以我们对所有大臣关于左右手之积进行排序 得到最多钱的大臣就是 ...

  7. 阅读基于sketch的软件定义网络测量数据平面硬件模型

    概要 硬件实现 基于sketch 功能:采集包数.流长数据,恢复五元组 重点:高速条件下性能较好,节省硬件资源 摘要: 提出一种基于sketch 数据结构的软件定义测量数据平面硬件模型,并在以现场可编 ...

  8. html input file accept

    *.3gpp audio/3gpp, video/3gpp 3GPP Audio/Video*.ac3 audio/ac3 AC3 Audio*.asf allpication/vnd.ms-asf ...

  9. 使同一个server上不同port的django应用可在同一个浏览器上打开

    如果我们有两个django应用site1和site2同时跑在同一个server的不同端口,同时我们在同一个浏览器的不同tab登录.那么这时就出出现这种情况,当我们登录site2时就会将site1上登录 ...

  10. MySQL的主从复制+双主模式

    MySQL的主从复制 部署环境: MySQL master 192.168.40.21 MySQL slave  192.168.40.22 思路: 当主MySQL上进行数据上的操作或者变化时,主My ...