==============================================================
面向对象编程有四大概念:封装,抽象,多态,继承,其共同构成了面向对象编程的四大支柱。
==============================================================
(四)继承
概念:在创建类时,该类可以从另一个类那里继承方法和变量。被继承的类,称为父类;继承的类则称为子类,子类继承了父类的所有属性和方法,同时还可以定义自己的属性和方法。
1.子类的方法__init__()
假如以电动汽车为例,示例如下:
class Car():------------------------------------------------------------1
"""一次模拟汽车的简单尝试"""
def __init__(self, make, model, year):
self.make = make
self.model = model
self.year = year
self.odometer_reading = 0
def get_descriptive_name(self):
long_name = str(self.year)+' '+self.make+' '+self.model
return long_name.title()
class ElectricCar(Car):-------------------------------------------2
"""电动汽车的独特之处"""
def __init__(self, make, model, year):--------------------3
"""初始化父类的属性"""
super().__init__(make, model, year)---------------------------4
my_tesla = ElectricCar('tesla', 'model s', 2016)-------------5
print(my_tesla.get_descriptive_name())
输出:
2016 Tesla Model S
上述代码中,创建子类时,父类必须包含在当前文件中,并且位于子类前面。代码中1处的Car()是父类,2处的ElectricCar(Car)是子类,即定义子类时,必须在括号内指定父类的名称。方法__init__()接受创建Car实例所需的信息(3处)。
子类中4处的super()是一个特殊函数,可以将父类和子类关联起来。super().__init__(make, model, year)这行代码让python调用ElectricCar的父类的方法__init__(),让ElectricCar实例包含父类的所有属性。父类也称为超类,名称super因此而得名。
在5处创建了ElectricCar的实例(对象),并将其存储在变量my_tesla中,这行代码调用ElectricCar类中定义的方法__init__(),而后者再让python调用父类Car中定义的方法__init__()。
2.给子类定义属性和方法
在上述代码中,给子类添加一个属性,以及描述该属性的方法。示例如下:
class Car():
--snip--
class ElectricCar(Car):
"""电动汽车的独特之处"""
def __init__(self, make, model, year):
"""初始化父类的属性"""
super().__init__(make, model, year)
#初始化电动汽车特有属性
self.battery_size = 70------------------------6
def describe_battery(self):------------------7
print('this car has a ' + str(self.battery_size) + '-KWh battery.')
my_tesla = ElectricCar('tesla', 'model s', 2016)
print(my_tesla.get_descriptive_name())
my_tesla.describe_battery()
输出:
2016 Tesla Model S
this car has a 70-KWh battery.
在6处给子类ElectricCar添加了新的属性,还在7处添加了一个名为describe_battery()的方法。
3.重写父类的方法
对于父类的方法,只要不符合子类模拟的实物的行为,都可以对其进行重写。因此,可以在子类中定义一个这样的方法,即它和要重写的父类方法同名,这样,python将不会考虑父类中的这个方法,而只会关注子类中的这个方法。
<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>