python调用父类方法的三种方式(super调用和父类名调用)

举报
python教程 发表于 2023/05/20 19:40:59 2023/05/20
826 0 0
【摘要】 子类调用父类的方法的三种方式:父类名.方法名(self)super(子类名,self).父类方法名()super().父类方法名注意:super()通过子类调用当前父类的方法,super默认会调用第一个父类的方法(适用于单继承的多层继承如下代码:# 自定义师傅类-古法class Master(object): # 方法 def make_cake(self): p...

子类调用父类的方法的三种方式:

  • 父类名.方法名(self)

  • super(子类名,self).父类方法名()

  • super().父类方法名

注意:super()通过子类调用当前父类的方法,super默认会调用第一个父类的方法(适用于单继承的多层继承

如下代码:

# 自定义师傅类-古法
class Master(object):

    # 方法
    def make_cake(self):
        print("古法煎饼果子")
# 自定义师傅类-现代
class School(object):

    # 方法
    def make_cake(self):
        print("现代煎饼果子")
# 自定义一个徒弟类
class Prentice(Master, School):

    # 方法
    def make_cake(self):
        print("猫氏煎饼果子")
        Master.make_cake(self)
        School.make_cake(self)

    # 古法
    def make_old_cake(self):
        # 01 方式(单和多继承 都适用)
        # Master.make_cake(self)

        # super默认会调用第一个父类的方法(适用于单继承 或者只想使用第一个父类的方法)

        # 02 方式 适用于新式类
        # 格式: super(子类类名, self).父类方法名()
        # super(Prentice, self).make_cake()

        # 03 方式 (适用于新式类) 02方式的简写
        super().make_cake()
    # 现代
    def make_new_cake(self):
        super().make_cake()
# 自定义一个对象 大猫
damao = Prentice()
# 猫氏
damao.make_cake()
# # 古法
# damao.make_old_cake()
# # 现代
# damao.make_new_cake()

super()调用父类的构造方法

如下代码:

class People:
    def __init__(self, name):
        self.name = name
    def say(self):
        print("我是人,名字为:", self.name)

class Animal:
    def __init__(self, food):
        self.food = food
    def display(self):
        print("我是动物,我吃", self.food)

#People中的name属性和say()会覆盖Animal类中的
class Person(People, Animal):
    pass
#Python小白学习交流群:711312441
xiaobai = Person("小白")
#Person类同时继承People和Animal,其中People在前。
#这意味着,在创建对象xiaobai时,其将会调用从People类继承来的构造函数,因此上面程序创建xiaobai对象的同时,还要给name属性进行赋值。
xiaobai.say()
xiaobai.display()

上面代码运行结果:

我是人,名字为: 小白
Traceback (most recent call last):
AttributeError: 'Person' object has no attribute 'food'
#从Animal类中继承的display()方法中,需要用到food属性的值,
#但由于People类的构造方法覆盖了Animal类的构造方法,使得在创建xiaobai对象时,Animal类的构造方法未得到执行,所以程序出错。

针对这种情况,正确的做法是定义Person类自己的构造方法(等同于重写第一个直接父类的构造方法),但是需要注意的是,在子类中定义构造方法,则必须在该方法中调用父类的构造方法。

  • 未绑定方式
  • 使用super()函数,但如果涉及多继承,该函数只能调用第一个直接父类的构造方法。

也就是说,涉及到多继承时,在子类构造函数中,调用第一个父类构造方法的方式有以上两种,而调用其他父类构造方法的方式只能使用未绑定方法。

class People:
    def __init__(self, name):
        self.name = name
    def say(self):
        print("我是人,名字为:", self.name)
class Animal:
    def __init__(self, food):
        self.food = food
    def display(self):
        print("我是动物,我吃", self.food)
class Person(People, Animal):
    #自定义构造方法
    def __init__(self, name, food):
        #调用第一个父类的构造方法
        super().__init__(name)
        #People.__init__(self, name)使用未绑定方法调用第一个父类的构造方法
        #调用其他父类的构造方法,需要手动给self传值
        Animal.__init__(self, food)
xiaobai = Person("xiaobai", "熟食")
xiaobai.say()
xiaobai.display()

运行结果:

我是人,名字为: xiaobai
我是动物,我吃 熟食

可以看到,Person类自定义的构造方法中,调用People类构造方法,可以使用super()函数,也可以使用未绑定方法。但是调用Animal类的构造方法,只能使用未绑定方法

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。