前面我们知道了在Python中如何继承。我们看下面的继承关系,Bird类有一个eat方法。BigBird继承了Bird,并且新增了sing方法。
class Bird:
def __init__(self):
self.hungry=True
def eat(self):
if self.hungry:
print('开始吃,好好吃...')
self.hungry=False
else:
print('吃饱了,不要了...')
b= Bird()
b.eat();
b.eat()
输出
开始吃,好好吃...
吃饱了,不要了...
子类,
class BigBird(Bird):
def __init__(self):
self.sound='小燕子,穿花衣,年年春天来这里...'
def sing(self):
print(self.sound)
bg = BigBird()
bg.sing()
bg.eat()
调用sing方法输出
小燕子,穿花衣,年年春天来这里...
调用eat报异常如下:
Traceback (most recent call last):
File "D:/work/Python/ClassElement2.py", line 27, in <module>
bg.eat()
File "D:/work/Python/ClassElement2.py", line 9, in eat
if self.hungry:
AttributeError: 'BigBird' object has no attribute 'hungry'
因为BigBird中没有调用父类Bird中的构造函数,所以没有初始化父类的hungry的值。如果想要eat方法能正常执行,我们需要在BigBird的构造函数中调用父类的构造函数。
如下,
class BBigBird(Bird):
def __init__(self):
Bird.__init__(self)
self.sound='小燕子,穿花衣,年年春天来这里...'
def sing(self):
print(self.sound)
bg = BBigBird()
bg.sing()
bg.eat()
输出
小燕子,穿花衣,年年春天来这里...
开始吃,好好吃...
因为在调用一个实例的方法时,该方法的self参数会被自动绑定到实例上。上面这种直接调用类的方法,比如Bird.__init__(self),其实没有实例绑定。这样的方法是未绑定的。
上面例子中,将当前BBigBird的实例作为self参数提供给未绑定的方法Bird.__init__,BBigBird就能够使用父类的构造函数,hungry会被赋值。
工程文件下载:https://download.csdn.net/download/yysyangyangyangshan/10797322