python面向对象之类的继承详解

时间:2021-12-15 13:55:38

一、概述 

  面向对象编程 (oop) 语言的一个主要功能就是“继承”。继承是指这样一种能力:它可以使用现有类的所有功能,并在无需重新编写原来的类的情况下对这些功能进行扩展。

  通过继承创建的新类称为“子类”或“派生类”,被继承的类称为“基类”、“父类”或“超类”,继承的过程,就是从一般到特殊的过程。在某些 oop 语言中,一个子类可以继承多个基类。但是一般情况下,一个子类只能有一个基类,要实现多重继承,可以通过多级继承来实现。

  继承概念的实现方式主要有2类:实现继承、接口继承。

实现继承是指使用基类的属性和方法而无需额外编码的能力。接口继承是指仅使用属性和方法的名称、但是子类必须提供实现的能力(子类重构爹类方法)。

  在考虑使用继承时,有一点需要注意,那就是两个类之间的关系应该是“属于”关系。例如,employee 是一个人,manager 也是一个人,因此这两个类都可以继承 person 类。但是 leg 类却不能继承 person 类,因为腿并不是一个人。

  oo开发范式大致为:划分对象→抽象类→将类组织成为层次化结构(继承和合成) →用类与实例进行设计和实现几个阶段。

二、类的继承

2.1 继承的定义

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class person(object):   # 定义一个父类
 
    def talk(self):    # 父类中的方法
        print("person is talking...."
 
 
class chinese(person):    # 定义一个子类, 继承person类
 
    def walk(self):      # 在子类中定义其自身的方法
        print('is walking...')
 
c = chinese()
c.talk()      # 调用继承的person类的方法
c.walk()     # 调用本身的方法
 
# 输出
 
person is talking....
is walking...

2.2 构造函数的继承 

  如果我们要给实例 c 传参,我们就要使用到构造函数,那么构造函数该如何继承,同时子类中又如何定义自己的属性?

继承类的构造方法:

       1.经典类的写法: 父类名称.__init__(self,参数1,参数2,...)

       2. 新式类的写法:super(子类,self).__init__(参数1,参数2,....)

?
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
class person(object):
 
    def __init__(self, name, age):
        self.name = name
        self.age = age
        self.weight = 'weight'
 
    def talk(self):
        print("person is talking....")
 
 
class chinese(person):
 
    def __init__(self, name, age, language):  # 先继承,在重构
        person.__init__(self, name, age)  #继承父类的构造方法,也可以写成:super(chinese,self).__init__(name,age)
        self.language = language    # 定义类的本身属性
 
    def walk(self):
        print('is walking...')
 
 
class american(person):
    pass
 
c = chinese('bigberg', 22, 'chinese')

  如果我们只是简单的在子类chinese中定义一个构造函数,其实就是在重构。这样子类就不能继承父类的属性了。所以我们在定义子类的构造函数时,要先继承再构造,这样我们也能获取父类的属性了。

子类构造函数基础父类构造函数过程如下:

实例化对象c ----> c 调用子类__init__() ---- > 子类__init__()继承父类__init__() ----- > 调用父类__init__()

python面向对象之类的继承详解

2.3 子类对父类方法的重写

  如果我们对基类/父类的方法需要修改,可以在子类中重构该方法。如下的talk()方法

?
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
class person(object):
 
    def __init__(self, name, age):
        self.name = name
        self.age = age
        self.weight = 'weight'
 
    def talk(self):
        print("person is talking....")
 
class chinese(person):
 
    def __init__(self, name, age, language):
        person.__init__(self, name, age)
        self.language = language
        print(self.name, self.age, self.weight, self.language)
 
    def talk(self):  # 子类 重构方法
        print('%s is speaking chinese' % self.name)
 
    def walk(self):
        print('is walking...')
 
c = chinese('bigberg', 22, 'chinese')
c.talk()
 
# 输出
bigberg 22 weight chinese
bigberg is speaking chinese

三、类继承的事例

?
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
class schoolmember(object):
    '''学习成员基类'''
    member = 0
 
    def __init__(self, name, age, sex):
        self.name = name
        self.age = age
        self.sex = sex
        self.enroll()
 
    def enroll(self):
        '注册'
        print('just enrolled a new school member [%s].' % self.name)
        schoolmember.member += 1
 
    def tell(self):
        print('----%s----' % self.name)
        for k, v in self.__dict__.items():
            print(k, v)
        print('----end-----')
 
    def __del__(self):
        print('开除了[%s]' % self.name)
        schoolmember.member -= 1
 
 
class teacher(schoolmember):
    '教师'
    def __init__(self, name, age, sex, salary, course):
        schoolmember.__init__(self, name, age, sex)
        self.salary = salary
        self.course = course
 
    def teaching(self):
        print('teacher [%s] is teaching [%s]' % (self.name, self.course))
 
 
class student(schoolmember):
    '学生'
 
    def __init__(self, name, age, sex, course, tuition):
        schoolmember.__init__(self, name, age, sex)
        self.course = course
        self.tuition = tuition
        self.amount = 0
 
    def pay_tuition(self, amount):
        print('student [%s] has just paied [%s]' % (self.name, amount))
        self.amount += amount
 
t1 = teacher('wusir', 28, 'm', 3000, 'python')
t1.tell()
s1 = student('haitao', 38, 'm', 'python', 30000)
s1.tell()
s2 = student('lichuang', 12, 'm', 'python', 11000)
print(schoolmember.member)
del s2
 
print(schoolmember.member)
 
 
 
# 输出
----end-----
just enrolled a new school member [haitao].
----haitao----
age 38
sex m
name haitao
amount 0
course python
tuition 30000
----end-----
just enrolled a new school member [lichuang].
3
开除了[lichuang]
2
开除了[wusir]
开除了[haitao]

到此这篇关于python面向对象之类的继承详解的文章就介绍到这了,更多相关python类的继承内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/bigberg/p/7182741.html