Python之面向对象新式类和经典类
Python之面向对象新式类和经典类
新式类和经典类的继承原理:
在Python3中,就只有新式类一种了。
先看Python3中新式类:
类是有继承顺序的:
Python的类是可以继承多个类的,也就是多继承。
Python的类如果继承了多个类,那么其寻找的方法有两种,分贝为:深度优先 and 广度优先。
当类是经典类时:多继承状态下,按深度优先查找。
当类是新式类时:多继承状态下,按广度优先查找。
广度优先的顺序:不走到头,再走完所有分支的情况下走最后的头。
#新式类的继承,在查找属性时遵循:广度优先 # 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() # # # print(F.__mro__) # print(F.mro()) #广度优先:F->D->B->E->C->A->object
MRO:
MRO是一种算法,用于计算在继承过程中,类的继承顺序。
所有父类的MRO列表并遵循如下的三条准则:
1、子类会优先于父类被检查。
2、多个父类会根据他们在列表中的顺序被检查。
3、 如果对下一个类存在两个合法的选择,选择第一个父类。
注意:MRO的用发只有新式类可以用,Python2的经典类是用不了的。
在Python2中的类的新式和经典的区别:
在Python2中的新式类中,最终的父类要写object,而Python3的新式类不用写。
其余的新式类和Python3一致。
Python2中的经典类的继承:
在Python2中的经典类继承是深度优先的查找原则:
#python2中经典类的继承,在查找属性时遵循:深度优先 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() # F->D->B->A->E->C
Super的用法:
在子类里调用父类的方法是,不要直接去调用,不要用 “类名. 方法” 的方法去调用。
而是用Super的方法。
Super只能用于新式类。
Super函数:
注意:Super函数的参数,第一个类名,一定是自己的类名。
#coding:utf-8 #super在python2中的用法: # 1:super(自己的类,self).父类的函数名字 # 2:super只能用于新式类 class People(object): def __init__(self,name,sex,age): self.name=name self.age=age self.sex=sex 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) self.language=language c=Chinese('egon','male',18) print (c.name,c.age,c.sex,c.language) ######## 在python3中 ######## class People: def __init__(self,name,sex,age): self.name=name self.age=age self.sex=sex 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) 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)