Python_继承_构造函数

本文探讨了在Python继承中遇到的构造函数问题。当子类SongBird重写构造函数后,由于未调用超类Bird的构造函数,导致初始化属性hungry未设置,从而引发错误。解决方法包括直接调用未关联的超类构造函数或者使用`super()`函数进行调用,以确保基本的初始化操作得到执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

class Bird:
    def __init__(self):   #构造函数
        self.hungry=True
    def eat(self):
        if self.hungry:
            print("Aaaah.....")
            self.hungry=False
        else:
            print("No, thanks!")

class SongBird(Bird):
    def __init__(self):
        self.sound="Squawk!"
    def sing(self):
        print(self.sound)

sb=SongBird()
sb.sing()

运行结果为为:

Squawk!

但是当运行sb.eat()时,会有如下报错:

'SongBird' object has no attribute 'hungry'

因为在SongBird中重写了构造函数,但新的构造函数没有包含任何初始化属性hungry的代码。
要消除这个错误,SongBird的构造函数必须调用其超类(Bird)的构造函数,以确保基本的初始化得以执行。为此,有两种方法:

1) 调用未关联的超类的构造函数

class Bird:   #超类
    def __init__(self):   #构造函数
        self.hungry=True
    def eat(self):
        if self.hungry:
            print("Aaaah.....")
            self.hungry=False
        else:
            print("No, thanks!")

class SongBird(Bird):  #子类
    def __init__(self):
        Bird.__init__(self)  #使用未关联的超类的构造函数
        self.sound="Squawk!"
    def sing(self):
        print(self.sound)

sb=SongBird()
sb.sing()
sb.eat()

运行结果:

Squawk!
Aaaah.....

2) 使用函数Super

class Bird:
    def __init__(self):
        self.hungry=True
    def eat(self):
        if self.hungry:
            print("Aaaah.....")
            self.hungry=False
        else:
            print("No, thanks!")

class SongBird(Bird):
    def __init__(self):
        super().__init__()  ###使用super函数,相当于调用了超类的构造函数。
        self.sound="Squawk!"
    def sing(self):
        print(self.sound)

sb=SongBird()
sb.sing()
sb.eat()

运行结果:

Squawk!
Aaaah.....
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值