继承(面向对象(OOP))
继承是面向对象编程最重要的特征之一,它源于人们认识客观世界的过程,是自然界普遍存在的一种现象。
Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对象是很容易的。本章节我们将详细介绍Python的面向对象编程。
如果你以前没有接触过面向对象的编程语言,那你可能需要先了解一些面向对象语言的一些基本特征,在头脑里头形成一个基本的面向对象的概念,这样有助于你更容易的学习Python的面向对象编程。
接下来我们先来简单的了解下面向对象的一些基本特征
面向对象技术简介
- 类(Class): 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
- 类变量:类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。
- 数据成员:类变量或者实例变量, 用于处理类及其实例对象的相关的数据。
- 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖(override),也称为方法的重写。
- 局部变量:定义在方法中的变量,只作用于当前实例的类。
- 实例变量:在类的声明中,属性是用变量来表示的。这种变量就称为实例变量,是在类声明的内部但是在类的其他成员方法之外声明的。
- 继承:即一个派生类(derived class)继承基类(base class)的字段和方法。继承也允许把一个派生类的对象作为一个基类对象对待。例如,有这样一个设计:一个Dog类型的对象派生自Animal类,这是模拟"是一个(is-a)"关系(例图,Dog是一个Animal)。
- 实例化:创建一个类的实例,类的具体对象。
- 方法:类中定义的函数。
- 对象:通过类定义的数据结构实例。对象包括两个数据成员(类变量和实例变量)和方法。
语法:
创建类
使用 class 语句来创建一个新类,class 之后为类的名称并以冒号结尾:
class ClassName:
'类的帮助信息' #类文档字符串
class_suite #类体
类的帮助信息可以通过ClassName.__doc__查看。
class_suite 由类成员,方法,数据属性组成。
方法重写:
如果你的父类方法的功能不能满足你的需求,你可以在子类重写你父类的方法:
class Fruit:
color = "绿色"
def harvest(self,color):
print("水果是:"+color+"的!")
print("水果已经收获......")
print("水果原来是:"+Fruit.color+"的!")
class Orange(Fruit):
color = "黄色"
def __init__(self):
print("\n我是橘子")
def harvest(self,color):
print("橘子是:" + color + "的!")
print("橘子已经收获......")
print("橘子原来是:" + Fruit.color + "的!")
C:\Users\user\AppData\Local\Programs\Python\Python37-32\python.exe E:/pycharm/pythonworker/learn/oop.py
水果是:绿色的!
水果已经收获......
水果原来是:绿色的!
我是橘子
橘子是:黄色的!
橘子已经收获......
橘子原来是:绿色的!
派生类中调用基类的__init__()方法:
在派生类中定义__init__()方法是,不会自动调用基类的__init__()方法。
class Fruit:
def __init__(self,color="绿色"):
Fruit.color = color
def harvest(self):
print("水果原来是:"+Fruit.color+"的!")
class Apple(Fruit):
def __init__(self):
# super().__init__()
print("\n我是苹果")
apple = Apple()
apple.harvest()
执行上面的代码后,将显示如图的异常信息。
C:\Users\user\AppData\Local\Programs\Python\Python37-32\python.exe E:/pycharm/pythonworker/learn/oop.py
我是苹果
Traceback (most recent call last):
File "E:/pycharm/pythonworker/learn/oop.py", line 20, in <module>
apple.harvest()
File "E:/pycharm/pythonworker/learn/oop.py", line 12, in harvest
print("水果原来是:"+Fruit.color+"的!")
AttributeError: type object 'Fruit' has no attribute 'color'
因此,要在派生类中使用基类的__inti__()方法,必须要进行初始化,即需要在派生类中使用super()函数调用基类的__init__()方法。如下
class Fruit:
def __init__(self,color="绿色"):
Fruit.color = color
def harvest(self):
print("水果原来是:"+Fruit.color+"的!")
class Apple(Fruit):
def __init__(self):
super().__init__() # super().__init__() 方法调用基类__init__()方法
print("\n我是苹果")
apple = Apple()
apple.harvest()
执行结果:
C:\Users\user\AppData\Local\Programs\Python\Python37-32\python.exe E:/pycharm/pythonworker/learn/oop.py
我是苹果
水果原来是:绿色的!