随笔 - 65  文章 - 0  评论 - 0  阅读 - 25257

类的继承

继承的优点:
1,节省代码.
2,规范代码.
初识继承:

#执行方法的时候先在自己的类中找,没有再去父类中找
只执行本类的方法 #在本类中要有执行的方法
只执行父类的方法. #本类中不写这个方法,自动去找父类中的方法
既执行本类又执行父类的方法
  1,父类名.方法名(参数)
  2,super().方法名(参数(self自动传值,不用写self))

举例:

 

 

单继承,多继承.
类:新式类,经典类.

单继承;
新式类经典类一样.

  


多继承:       #python3中没有经典类,都是新式类,自动继承object类.
新式类:广度优先     类名.mro()#查询类的继承顺序
经典类:深度优先.     #python2中才有经典类,继承object类之后就是新式类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
class A:
    def func(self):
        print('IN A')
class B(A):
    pass
    # def func(self):
    #     print('IN B')
class C(A):
    pass
    # def func(self):
    #     print('IN C')
class D(B):
    pass
    # def func(self):
    #     print('IN D')
class E(C):
    pass
    # def func(self):
    #     print('IN E')
class F(D,E):
    pass
    # def func(self):
    #     print('IN F')
f1 = F()
f1.func()
print(F.mro())  # 查询类的继承顺序
 
#F,D,B,E,C,A
#先写出所有路的继承顺序,D,B,A    E,C,A在写出继承的顺序D,E
#以每一条路的第一位为头,后面的为尾
#判断第一条路的头在不在后面的尾里面
#如果在
#看另一条路的头在不在
#如果不在
#删除每一条路的这个字母
#添加到另一个列表中
#依次循环
#得到的那个新列表前面加上最后的那个子类名
#就是继承的顺序

  

 

  

posted on   你们都厉害  阅读(143)  评论(0编辑  收藏  举报

点击右上角即可分享
微信分享提示