Python类的继承与多态详细介绍
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python类的继承与多态详细介绍相关的知识,希望对你有一定的参考价值。
参考技术A类(Class): 用来描述具有相同的属性和方法的对象的集合。
类变量:类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。
类有一个名为 __init__() 的特殊方法(构造方法),该方法在类实例化时会自动调用
self:self 代表的是类的实例,代表当前对象的地址,而 self.class 则指向类。
类调用 Car.weight
实例化 car01=Car(5)
实例对象调用 car01.weght
我们在构造类时,Python3默认我们继承了object这个基类,我个人理解object就是个空的类,可以不用管为何要在括号中写上object,这是Python3的特性,在python2中如果你没有写object的话不会默认继承了object这个基类。
同样的我们自己希望继承的父类只需要把objetc改为我们自己定义的类名即可。子类中可以拥有父类中所有的公有属性和方法,但是可以通过在变量名前加下划线使其变为私有,这样子类就不可以访问父类中的成员了。
以下三个公交车类的父类均为客车类,我们可以写一个funcs方法使得每次调用funcs方法时,传入不同的对象以执行不同的func方法,具体实现如下:
主函数 :
可以看到,我将小 汽车 实例化为带有重量为5t的一个具体对象,将客车实例化为带有重量为20t的一个具体对象,将三个公交车实例化为带有重量为15t的一个具体对象.
如上图所示,我每次在调用funcs方法时都传入了一个实例化对象,funcs根据不同的对象执行相应的内部方法。
python基础之继承原理,多态与封装
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列表就是一个简单的所有基类的线性顺序列表。
#广度优先: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__) #只有新式才有这个属性可以查看线性列表,经典类没有这个属性
继承原理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,深度优先
#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() #广度优先
#执行顺序是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
#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‘,‘18‘) 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只能用于新式类
以上是关于Python类的继承与多态详细介绍的主要内容,如果未能解决你的问题,请参考以下文章