先看一个例子:
class Bird(object):
def __init__(self):
self.hungry=True
def eat(self):
if self.hungry:
print 'Aaaah...'
self.hungry=False
else:
print 'No,Thank you!'
class SongBird(Bird):
def __init__(self):
self.sound='Squawk!'
def sing(self):
print self.sound
b=Bird()
b.eat()
b.eat()
sb =SongBird()
sb.sing()
sb.eat()
运行结果如下:
异常很清楚的说明了错误:SongBird没有hungry特性。因为在SongBird中,构造方法被重写,但新的构造方法没有任何关于初始化hungry特性的代码。为了达到预期的效果,SongBird的构造方法必须调用其超类Bird的构造方法来确保进行基本的初始化。有两种方法能达到这个目的:
1、调用超类构造方法的未绑定版本
2、使用super函数
1、超类构造函数的未绑定版本:
只需对子类的修改如下:
class SongBird(Bird):
def __init__(self):
Bird.__init__(self)
self.sound='Squawk!'
def sing(self):
print self.sound
由于此处并没有将Bird类绑定到self参数上,因此称为未绑定方法。运行结果如下:
2、使用super函数:
使用方法:当前的类和对象可以super函数的参数使用,调用函数返回的对象的任何方法都是调用超类的方法,而不是当前类的方法。
对子类的修改如下:
class SongBird(Bird):
def __init__(self):
super(SongBird,self).__init__()#此时调用的就是超类的init方法
self.sound='Squawk!'
def sing(self):
print self.sound
运行结果同第一种方法
需结合例子加以体会
参考书籍:《Python基础教程(第2版·修订版)》P141