继承。属于面向对象的进一步抽象。
为何说是进一步抽象呢?在使用面向对象编程的时候,也就是写类的时候,发现很多类中有共同的内容(属性和方法),这样又变成了重复编码了,能不能减少一点代码呢?
比如,我们写一个教师类,有姓名、年龄、身高、教师编号等属性,有讲课、吃饭、睡觉、打豆豆等行为(方法);然后写一个学生类,有姓名、年龄、身高、学号等属性,有学习、吃饭、睡觉、打豆豆等行为;写一个老司机类,有姓名、年龄、身高、驾驶证号等属性,有开车、吃饭、睡觉、打豆豆等行为。
细想一下,是不是大家都有姓名、年龄、身高等属性,也共同拥有吃饭、睡觉、打豆豆等行为?那么是不是在描述的时候我们只用单独描述他们特殊的属性和行为,而这些共同的属性和行为都可以归类到人类中呢?
当然可以,这就是继承啦。将子类们共有的属性和方法抽象到父类(超类)中,子类们只需要通过继承父类,就能拥有这些共有的属性了。
继承可以使得子类具有父类的属性和方法或者重新定义、追加属性和方法等。
- 子类拥有父类的特征,而父类没有。父类更通用,子类更具体;
- 通过子类继承父类,子类拥有父类的所有属性和方法(私有的除外);
- 子类可以拥有自己独特的属性和方法。
# 定义人类类
class Person():
def __init__(self, name, age, height, number):
self.name = name
self.number = number
self.age = age
self.height = height
def talk(self, who):
print('%s在和%s说话' % (self.name, who))
def hit_doudou(self):
print('%s正在打豆豆...' % self.name)
# 下面写一个学生类继承人类
class Student(Person): # 继承的写法:在类申明的时候,括号中写需要继承的父类名
def __init__(self, class_, name, age, height, number):
# 学生除了人类中定义的属性,还有班级属性
self.class_ = class_
super().__init__(name, age, height, number)
# super()函数,如果重写了父类的方法,你在子类中又需要父类的方法
# 就需要使用super()函数,重新调用父类的同名方法。
def talk(self): # 重写父类的同名方法
print('%s在讨论学习' % self.name)
def study(self):
print('%s正在学习英语...' % self.name)
# 写一个教师类,继承自人类
class Teacher(Person):
# 只定义了一个讲课方法
# 其余方法都继承自父类
def teach(self):
# 调用父类的属性
print('%s在讲课'% self.name)
# 实例化子类
s = Stuent('一年级二班', '豆豆', 7, 40, '13101')
s.hit_doudou() # 子类对象调用父类的方法
通过继承,子类拥有父类中的所有属性和方法。
- 子类可以在定义方法时调用父类的属性和方法;
- 子类的对象可以访问父类的属性和方法;
- 子类如果对某些方法有更具体的定义,可以重写父类的方法。
重写:如果子类和父类有同名的方法,就认为这是重写。
那么这个时候在子类或子类对象调用的时候,会以子类为准,我们这种情况就是子类重写了。这也就是所谓的父类更通用、子类更具体。
super():重写了父类的方法,而在子类中又需要用到父类的方法。可以使用该函数调用父类的方法。
主要用于__init__
方法,当你子类需要添加实例属性时,必定要重写__init__
方法,但是重写后父类的__init__
方法会被覆盖,父类中的实例属性就没有了,于是需要在子类中重写__init__
方法后需要再调用父类的方法以保证父类的属性。