1.什么是继承? 继承是一种创建新的类的方式。
class A:
pass
class B:
pass
2.如何继承---->如何寻找继承关系

现实生活中找继承关系是自下而上,在程序中写是自上而下
继承是一种"是"的关系:
人类、猪类、狗类都是继承动物类,因为他们都是动物

3.为什么要用继承?
解决代码重用问题?解决的是:什么是什么的问题-->继承

4.派生:子类继承了父类的属性,然后衍生(或派生)出自己新的属性
如果子类衍生出的新的属性与父类的某个属性名字相同
那么再调用子类的这个属性,就以子类自己这里的为准了
5.在子类中重用父类的函数,父类名.父类的函数(参数)

6.组合对继承来说,也是用来重用代码,但是组合描述的是一种"有"的关系
老师有课程
学生有成绩
学生有课程
学校有老师
学校有学生

  1. class Course:
  2. def __init__(self,name,price,period):
  3. self.name=name
  4. self.price=price
  5. self.period=period
  6. class Teacher:
  7. def __init__(name.course):
  8. self.name=name
  9. self.course=course
  10. class Student:
  11. def __init__(name.course):
  12. self.name=name
  13. self.course=course
  14. python=Course('python',15800,'7m')
  15. t1=Teacher('egon',python)
  16. s1=Student('alex',python)
  17.  
  18. print(s1.course.name)
  19. print(s1.course.period)

组合示例

继承原理1(python3中的新式类):

  1. #新式类的继承,在查找属性时遵循:广度优先
  2. class A(object): #A继承object类,在Python3中写不写都一样
  3. def test(self):
  4. print('from A')
  5. pass
  6. class X(A):
  7. # def test(self):
  8. # print('from X')
  9. pass
  10. class B(X):
  11. # def test(self):
  12. # print('from B')
  13. pass
  14. class C(A):
  15. def test(self):
  16. print('from C')
  17. pass
  18. class D(B):
  19. # def test(self):
  20. # print('from D')
  21. pass
  22. class E(C):
  23. def test(self):
  24. print('from E')
  25. pass
  26. class F(D,E):
  27. # def test(self):
  28. # print('from F') #从F自己这里找
  29. pass
  30. f1=F()
  31. f1.test()
  32. print(F.mro())
  33. #MRO程序列表会生成一个列表
  34. #python到底是如何实现继承的,对于定义的每一个类,python会计算出一个方法解析顺序(MRO)列表,这个MRO列表就是一个简单的所有基类的线性顺序列表。

继承原理示例1-1

  1. #广度优先:F->D->B->E->C->A->object
    #广度优先:从左边开始走,但是不走到头,再从右边开始走
  1. class A(object):
  2. def test(self):
  3. print('from A')
  4. pass
  5.  
  6. class B(A):
  7. # def test(self):
  8. # print('from B')
  9. pass
  10. class C(A):
  11. # def test(self):
  12. # print('from C')
  13. pass
  14.  
  15. class D(B):
  16. # def test(self):
  17. # print('from D')
  18. pass
  19. class E(C):
  20. # def test(self):
  21. # print('from E')
  22. pass
  23. class F(D,E):
  24. # def test(self):
  25. # print('from F')
  26. pass
  27. f1=F()
  28. f1.test() #先在f1找,没有,然后再F找
  29. print(F.__mro__) #只有新式才有这个属性可以查看线性列表,经典类没有这个属性

继承原理示例1-2

继承原理2(python3中的新式类):

  1. # Auther:bing
  2. #新式类的继承,在查找属性时遵循:广度优先
  3. class X(object):
  4. def test(self):
  5. print('from X')
  6. pass
  7. class Y(object):
  8. def test(self):
  9. print('from Y')
  10. pass
  11. class B(X):
  12. def test(self):
  13. print('from B')
  14. pass
  15. class C(Y):
  16. def test(self):
  17. print('from C')
  18. pass
  19. class D(B):
  20. def test(self):
  21. print('from D')
  22. pass
  23. class E(C):
  24. def test(self):
  25. print('from E')
  26. pass
  27. class F(D,E):
  28. def test(self):
  29. print('from F')
  30. pass
  31. f1=F()
  32. f1.test()
  33. #深度优先
  34. #F-->D-->B-->X-->E-->C-->Y-->object,先从左边开始找,再找右边,相当于一个V形

继承原理2

继承原理图2,深度优先

  1. #F-->D-->B-->X-->E-->C-->Y-->object,先从左边开始找,再找右边,相当于一个V形

继承原理3(python3中的新式类):

  1. class A(object):
  2. def test(self):
  3. print('from A')
  4. pass
  5. class B(A):
  6. def test(self):
  7. print('from B')
  8. pass
  9. class C(A):
  10. def test(self):
  11. print('from C')
  12. pass
  13. class D(A):
  14. def test(self):
  15. print('from D')
  16. pass
  17. class E(B):
  18. def test(self):
  19. print('from E')
  20. pass
  21. class F(C):
  22. def test(self):
  23. print('from F')
  24. pass
  25. class G(D):
  26. def test(self):
  27. print('from G')
  28. pass
  29. class H(E,F,G):
  30. def test(self):
  31. print('from H')
  32. pass
  33. h1=H()
  34. h1.test()
  35.  
  36. #广度优先

继承原理3

#执行顺序是E-B-F-C-G-D-A-object,先从左边,再从中间在从右边找

  1. #经典类的继承
  2. class A:
  3. def test(self):
  4. print('from A')
  5. pass
  6. class B(A):
  7. def test(self):
  8. print('from B')
  9. pass
  10. class C(A):
  11. def test(self):
  12. print('from C')
  13. pass
  14. class D(B):
  15. def test(self):
  16. print('from D')
  17. pass
  18. class E(C):
  19. def test(self):
  20. print('from E')
  21. pass
  22. class F(D,E):
  23. def test(self):
  24. print('from F')
  25. pass
  26. f1=F()
  27. f1.test()
  28. # print(F.__mro__)
  29. #MRO程序列表会生成一个列表
  30. #python到底是如何实现继承的,对于定义的每一个类,python会计算出一个方法解析顺序(MRO)列表,这个MRO列表就是一个简单的所有基类的线性顺序列表。
  31. #F-D-B-A-E-C-object

python2中经典类的继承

#F-D-B-A-E-C-object

super用法:

  1. #super在Python3中的用法:
  2. class People:
  3. def __init__(self,name,sex,age):
  4. self.name=name
  5. self.sex=sex
  6. self.age=age
  7. def walk(self):
  8. print('%s is walking' %self.name)
  9.  
  10. class Chinese(People):
  11. country='China'
  12. def __init__(self,name,sex,age,language='Chinese'):
  13. # self.name=name
  14. # self.sex=sex
  15. # self.age=age
  16. # People.__init__(self,name,sex,age)
  17. super(Chinese,self).__init__(name,sex,age) #调用父类(People类)的__init__方法(绑定方法)
  18. self.language=language
  19. def walk(self,x):
  20. super().walk()
  21. print('子类的x',x)
  22. c=Chinese('egon','male','')
  23. print(c.name,c.age,c.sex,c.language)
  24. c.walk(123)
  25.  
  26. ----------输出--------
  27. egon 18 male Chinese
  28. egon is walking
  29. 子类的x 123
  30.  
  31. #super在python2中的用法:
  32. #1:super(自己的类,self).父类的函数名称
  33. #2:super只能用于新式类

super应用

多态与多态性:

  1. 多态指的是一类事物有多种形态,(一个抽象类有多个子类,因而多态的概念依赖于继承)
    1、序列类型有多种形态:字符串,列表,元组
    2、动物有多种形态:人,狗,猪
    python默认就支持多态,python对类型没有任何限制,可以定义函数的参数,可以传入不同的对象进来
    多态性依赖于:
    1.继承
  2.  
  3.  2.定义统一的接口,可以传入不同类型的值,但是调用的逻辑都一样,执行的结果却不一样
    多态示例:
  1. class Animal: #多态:同一种事物的多种形态
  2. def run(self):
  3. raise AttributeError('子类必须实现这个方法')
  4.  
  5. class People(Animal):
  6. def run(self):
  7. print('人正在走')
  8. class Pig(Animal):
  9. def run(self):
  10. print('pig is walking')
  11. class Dog(Animal):
  12. def run(self):
  13. print('dog is running')
  14. peo1=People() #每一个对象都可以调用run()方法
  15. pig1=Pig() ##每一个对象都可以调用run()方法
  16. d1=Dog()
  17.  
  18. # peo1.run()
  19. # pig1.run()
  20. #统一的接口
  21. def func(obj): #obj这个参数没有类型限制,可以传入不同类型的值
  22. obj.run() #调用的逻辑都一样,执行的结果却不一样
  23. func(peo1)
  24. func(pig1)
  25. func(d1)

多态示例1:

  1. >>> a="hello" #定义一个字符串
  2. >>> l=[1,2,3] #定义一个列表
  3. >>> def func(obj): #定义一个函数
  4. ... return obj.__len__() #返回该数据类型的长度
  5. ...
  6. >>> func(a) 调用func函数
  7. 5
  8. >>> func(l)
  9. 3
  10.  
  11. >>> l=[1,2,3,4]
  12. >>> t=(1,2)
  13. >>> d={'a':1}
  14. >>> func(l)
  15. 4
  16. >>> func(t)
  17. 2
  18. >>> func(d)
  19. 1

多态示例2

封装:

  1. #封装,隔离复杂度
  2. class A:
  3. X=1
  4. def test(self):
  5. print('from A')
  6.  
  7. print(A.X)
  8. A.test(123455)
  9. a=A()
  10. a.y=1
  11. print(a.y)

封装示例1

  1. class A:
  2. __x=1 #_A__x
  3. def __test(self): #_A__test
  4. print('from A')
  5. print(A.__x)
  6. print(A.__dict__)
  7. print(A._A__x)
  8. a=A()
  9. print(a._A__x)
  10. print(A.__dict__)
  11. A._A__test(123)
  12. print(A._A__test(123))
  13. a=A()
  14. a._A__test()
  15. __名字,这种语法,只有在定义的时候才会有变形的效果,如果类或者对象已经产生了,就不会有变形效果
  16.  
  17. class B:
  18. pass
  19. B.__x=1
  20. print(B.__dict__)
  21.  
  22. b=B()
  23. b.__x=1
  24. print(b.__dict__)
  25. print(b.__x)

封装示例2

  1. class A:
  2. def fa(self):
  3. print('from A')
  4. def test(self):
  5. self.fa()
  6. class B(A):
  7. def fa(self):
  8. print('from B')
  9. b=B()
  10. b.test() #b.test-->B----A b.fa()

封装示例3

  1. #在定义阶段会变形
  2. class A:
  3. def __fa(self): #变形成 _A__fa
  4. print('from A')
  5. def test(self):
  6. self.__fa() #变形成 self._A__fa
  7. class B(A):
  8. def __fa(self): #_B__fa
  9. print('from B')
  10. b=B() #self._A__fa
  11. b.test() #b.test-->B----A b.fa()

封装示例4

  1. class A:
  2. def __init__(self):
  3. self.__x=1
  4. def tell(self): #定义在类的内部,在类内部可以用__x调用,通过调用接口函数往外访问,相当于用__语法变形了,但是没有限制它能对外访问
  5. print(self.__x)
  6. a=A()
  7. print(a.__dict__)
  8. # print(a.__x) #在类外部不能直接调用类内部的函数,只要隐藏起来了,外部就是不让访问,好处是实现了真正的隐藏,外部根本拿不到。坏处是:如果考虑不周到,把一些本不该隐藏的属性隐藏起来了,那么外部访问只能在类内部定义接口,一堆接口会导致面条式代码
  9. print(a._A__x)
  10. a.tell() #在类外部调用

封装示例5

python基础之继承原理,多态与封装的更多相关文章

  1. Python 中的继承、多态和封装

    涉及问题: Python 中如何实现多继承,会有什么问题? Python 中的多态与静态方法有什么区别? 答案要点如下: Python 中的继承,就是在定义类时,在括号中声明父类,简单示例如下: cl ...

  2. Python面向对象中的继承、多态和封装

    Python面向对象中的继承.多态和封装 一.面向对象的三大特性 封装:把很多数据封装到⼀个对象中,把固定功能的代码封装到⼀个代码块, 函数,对象, 打包成模块. 这都属于封装思想. 继承:⼦类可以⾃ ...

  3. 二十二. Python基础(22)--继承

    二十二. Python基础(22)--继承 ● 知识框架   ● 继承关系中self的指向 当一个对象调用一个方法时,这个方法的self形参会指向这个对象 class A:     def get(s ...

  4. Python 面向对象编程 继承 和多态

    Python 面向对象编程 继承 和多态 一:多继承性 对于java我们熟悉的是一个类只能继承一个父类:但是对于C++ 一个子类可以有多个父亲,同样对于 Python一个类也可以有多个父亲 格式: c ...

  5. Java学习:面向对象三大特征:封装、继承、多态之封装性

    面向对象三大特征:封装.继承.多态. 封装性在Java当中的体现: 方法就是一种封装 关键字private也是一种封装 封装就是将一些细节信息隐藏起来,对于外界不可见. 问题描述:定义Person的年 ...

  6. python基础之继承实现原理、子类调用父类的方法、封装

    继承实现原理 python中的类可以同时继承多个父类,继承的顺序有两种:深度优先和广度优先. 一般来讲,经典类在多继承的情况下会按照深度优先的方式查找,新式类会按照广度优先的方式查找 示例解析: 没有 ...

  7. python:类的基本特征------继承、多态与封装

    一.继承 1,什么是继承 继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类,父类又可称为基类或超类,新建的类称为派生类或子类 python中类的继承分为:单继承和多继承 cl ...

  8. Day7 初识面向对象,面向对象之继承、多态和封装

    一.面向对象引言 一.面向对象的程序设计的由来 详述见:http://www.cnblogs.com/linhaifeng/articles/6428835.html 二.面向对象引子 写一个简单程序 ...

  9. python类的继承和多态

    现在属于是老年人的脑子,东西写着写着就忘了,东西记着记着就不知道了.之前学C++的时候就把类.对象这块弄得乱七八糟,现在是因为很想玩python,所以就看看python的类和对象. 就像说的,类有三个 ...

随机推荐

  1. Docker下载地址(官网实在太慢)

    官网因为大家都懂得各种原因,访问简直慢如狗. 找到一个网站,下载很快. 如下: https://oomake.com/download/docker-windows

  2. jsp创建cookie

    <jsp:include flush="true" page="header.jsp" /> <script type="text/ ...

  3. 词性标注算法之CLAWS算法和VOLSUNGA算法

    背景知识 词性标注:将句子中兼类词的词性根据上下文唯一地确定下来. 一.基于规则的词性标注方法 1.原理 利用事先制定好的规则对具有多个词性的词进行消歧,最后保留一个正确的词性. 2.步骤 ①对词性歧 ...

  4. HDU - 6370 Werewolf 2018 Multi-University Training Contest 6 (DFS找环)

    求确定身份的人的个数. 只能确定狼的身份,因为只能找到谁说了谎.但一个人是否是民,无法确定. 将人视作点,指认关系视作边,有狼边和民边两种边. 确定狼的方法只有两种: 1. 在一个仅由一条狼边组成的环 ...

  5. Android bluetooth介绍

    Android bluetooth介绍(一):基本概念及硬件接口Android bluetooth介绍(二): android 蓝牙代码架构及其uart 到rfcomm流程Android blueto ...

  6. FIFO设计验证经验谈

    概述: FIFO是电路设计中非常重要的一个基本电路.一般的超大规模集成电路中,都会用到FIFO.所以,FIFO是每个SOC设计和验证工程师必须掌握的一种核心电路. FIFO电路又分为异步FIFO和同步 ...

  7. CSS气泡提示框 可自定义配置箭头

    在线演示 本地下载

  8. Spring AOP(1)

  9. centos上mailx通过465端口发送邮件

    最近在看zabbix发送邮件的时候,发现自己的邮件总是无法发送,这里可能是外网防火墙禁止25端口,那么如何绕过25端口呢?  我使用的是163邮箱的TSL加密协议465端口 由于mailx基本配置很简 ...

  10. Spring积累

    <tx:annotation-driven/>  (Spring的XML配置里两大Bean的声明之一) 那我们是否就可以在程序中所有被spring管理的类(@Controller.@Ser ...