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

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

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

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

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

class Course:
def __init__(self,name,price,period):
self.name=name
self.price=price
self.period=period
class Teacher:
def __init__(name.course):
self.name=name
self.course=course
class Student:
def __init__(name.course):
self.name=name
self.course=course
python=Course('python',15800,'7m')
t1=Teacher('egon',python)
s1=Student('alex',python) print(s1.course.name)
print(s1.course.period)

组合示例

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

#新式类的继承,在查找属性时遵循:广度优先
class A(object): #A继承object类,在Python3中写不写都一样
def test(self):
print('from A')
pass
class X(A):
# def test(self):
# print('from X')
pass
class B(X):
# def test(self):
# print('from B')
pass
class C(A):
def test(self):
print('from C')
pass
class D(B):
# def test(self):
# print('from D')
pass
class E(C):
def test(self):
print('from E')
pass
class F(D,E):
# def test(self):
# print('from F') #从F自己这里找
pass
f1=F()
f1.test()
print(F.mro())
#MRO程序列表会生成一个列表
#python到底是如何实现继承的,对于定义的每一个类,python会计算出一个方法解析顺序(MRO)列表,这个MRO列表就是一个简单的所有基类的线性顺序列表。

继承原理示例1-1

#广度优先:F->D->B->E->C->A->object
#广度优先:从左边开始走,但是不走到头,再从右边开始走
class A(object):
def test(self):
print('from A')
pass class B(A):
# def test(self):
# print('from B')
pass
class C(A):
# def test(self):
# print('from C')
pass class D(B):
# def test(self):
# print('from D')
pass
class E(C):
# def test(self):
# print('from E')
pass
class F(D,E):
# def test(self):
# print('from F')
pass
f1=F()
f1.test() #先在f1找,没有,然后再F找
print(F.__mro__) #只有新式才有这个属性可以查看线性列表,经典类没有这个属性

继承原理示例1-2

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

# Auther:bing
#新式类的继承,在查找属性时遵循:广度优先
class X(object):
def test(self):
print('from X')
pass
class Y(object):
def test(self):
print('from Y')
pass
class B(X):
def test(self):
print('from B')
pass
class C(Y):
def test(self):
print('from C')
pass
class D(B):
def test(self):
print('from D')
pass
class E(C):
def test(self):
print('from E')
pass
class F(D,E):
def test(self):
print('from F')
pass
f1=F()
f1.test()
#深度优先
#F-->D-->B-->X-->E-->C-->Y-->object,先从左边开始找,再找右边,相当于一个V形

继承原理2

继承原理图2,深度优先

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

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

class A(object):
def test(self):
print('from A')
pass
class B(A):
def test(self):
print('from B')
pass
class C(A):
def test(self):
print('from C')
pass
class D(A):
def test(self):
print('from D')
pass
class E(B):
def test(self):
print('from E')
pass
class F(C):
def test(self):
print('from F')
pass
class G(D):
def test(self):
print('from G')
pass
class H(E,F,G):
def test(self):
print('from H')
pass
h1=H()
h1.test() #广度优先

继承原理3

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

#经典类的继承
class A:
def test(self):
print('from A')
pass
class B(A):
def test(self):
print('from B')
pass
class C(A):
def test(self):
print('from C')
pass
class D(B):
def test(self):
print('from D')
pass
class E(C):
def test(self):
print('from E')
pass
class F(D,E):
def test(self):
print('from F')
pass
f1=F()
f1.test()
# print(F.__mro__)
#MRO程序列表会生成一个列表
#python到底是如何实现继承的,对于定义的每一个类,python会计算出一个方法解析顺序(MRO)列表,这个MRO列表就是一个简单的所有基类的线性顺序列表。
#F-D-B-A-E-C-object

python2中经典类的继承

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

super用法:

#super在Python3中的用法:
class People:
def __init__(self,name,sex,age):
self.name=name
self.sex=sex
self.age=age
def walk(self):
print('%s is walking' %self.name) class Chinese(People):
country='China'
def __init__(self,name,sex,age,language='Chinese'):
# self.name=name
# self.sex=sex
# self.age=age
# People.__init__(self,name,sex,age)
super(Chinese,self).__init__(name,sex,age) #调用父类(People类)的__init__方法(绑定方法)
self.language=language
def walk(self,x):
super().walk()
print('子类的x',x)
c=Chinese('egon','male','')
print(c.name,c.age,c.sex,c.language)
c.walk(123) ----------输出--------
egon 18 male Chinese
egon is walking
子类的x 123 #super在python2中的用法:
#1:super(自己的类,self).父类的函数名称
#2:super只能用于新式类

super应用

多态与多态性:

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

多态示例1:

>>> a="hello"    #定义一个字符串
>>> l=[1,2,3] #定义一个列表
>>> def func(obj): #定义一个函数
... return obj.__len__() #返回该数据类型的长度
...
>>> func(a) 调用func函数
5
>>> func(l)
3 >>> l=[1,2,3,4]
>>> t=(1,2)
>>> d={'a':1}
>>> func(l)
4
>>> func(t)
2
>>> func(d)
1

多态示例2

封装:

#封装,隔离复杂度
class A:
X=1
def test(self):
print('from A') print(A.X)
A.test(123455)
a=A()
a.y=1
print(a.y)

封装示例1

class A:
__x=1 #_A__x
def __test(self): #_A__test
print('from A')
print(A.__x)
print(A.__dict__)
print(A._A__x)
a=A()
print(a._A__x)
print(A.__dict__)
A._A__test(123)
print(A._A__test(123))
a=A()
a._A__test()
__名字,这种语法,只有在定义的时候才会有变形的效果,如果类或者对象已经产生了,就不会有变形效果 class B:
pass
B.__x=1
print(B.__dict__) b=B()
b.__x=1
print(b.__dict__)
print(b.__x)

封装示例2

class A:
def fa(self):
print('from A')
def test(self):
self.fa()
class B(A):
def fa(self):
print('from B')
b=B()
b.test() #b.test-->B----A b.fa()

封装示例3

#在定义阶段会变形
class A:
def __fa(self): #变形成 _A__fa
print('from A')
def test(self):
self.__fa() #变形成 self._A__fa
class B(A):
def __fa(self): #_B__fa
print('from B')
b=B() #self._A__fa
b.test() #b.test-->B----A b.fa()

封装示例4

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

    设有一台Linux服务器,利用iptables作为防火墙,要求新建一条名为MYCHAIN的新链,来实现只允许开放本机的http服务,其余协议和端口均拒绝. 脚本: [root@miyan ~]# ca ...

  2. python识别一段由字母组成的字符串是拼音还是英文单词

    环境:win10 python3.6 先说一下算法思想: 首先建立本地拼音库(不带声调).使用贪婪算法将字符串从左向右扫描,将字符串与本地拼音库(这里提供给大家一个)进行匹配,当发现匹配成功时继续扫描 ...

  3. 练T25- focus必看!所有成功截图汇总

    http://www.guokr.com/post/565880/ 25914人加入此小组 发新帖 练T25- focus必看!所有成功截图汇总! 读图模式 作家向威 作家 2014-02-22 07 ...

  4. 浅谈WebService SOAP、Restful、HTTP(post/get)请求

    http://www.itnose.net/detail/6189456.html 浅谈WebService SOAP.Restful.HTTP(post/get)请求 2015-01-09 19:2 ...

  5. 初学hadoop的个人历程

       在学习hadoop之前,我就明确了要致力于大数据行业,成为优秀的大数据研发工程师的目标,有了大目标之后要分几步走,然后每一步不断细分,采用大事化小的方法去学习hadoop.下面开始叙述我是如何初 ...

  6. memcached单点

    一.Repcached (memcached同步补丁) 下载地址:http://sourceforge.net/projects/repcached/files/repcached/2.2.1-1.2 ...

  7. $python包管理工具pip的安装和使用

    pip是python的一个非常好用的包管理工具,可以用来很方便地安装和管理各种三方库,本文对其基本用法进行介绍. 安装pip Windows系统上安装 python 2.7.9及以上版本的window ...

  8. hadoop---Java 网络IO编程总结BIO、NIO、AIO

    转载请注明出处:http://blog.csdn.net/anxpp/article/details/51512200,谢谢! 本文会从传统的BIO到NIO再到AIO自浅至深介绍,并附上完整的代码讲解 ...

  9. 20145222黄亚奇《网络对抗》MSF基础应用

    实践目标 掌握metasploit的基本应用方式. 具体需要完成(1)ms08_067;(2)ms11_050:(3)Adobe(4)成功应用任何一个辅助模块. 实验内容 掌握metasploit的基 ...

  10. SpringBoot AOP示例

    AOP主要注解: @Aspect,作用在类上,说明这是一个Aspect切面类. @Pointcut,用来描述,你需要在哪些类的哪些方法中植入你的代码. @Adive,与Pointcut配合使用,主要说 ...