python调用父类方法的三种方式(super调用和父类名调用)
Posted Python学习
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python调用父类方法的三种方式(super调用和父类名调用)相关的知识,希望对你有一定的参考价值。
子类调用父类的方法的三种方式:
-
父类名.方法名(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类的构造方法,只能使用未绑定方法
python中子类调用父类的方法
1子类调用父类构造方法
class Animal(object): def __init__(self): print("init Animal class~") def run(self): print("animal run!") class Dog(Animal): def __init__(self): #若子类没有重写构造方法,则会调用父类的。否则python不会自动调用父类构造方法。
#显式的调用父类构造方法的三种方式 #Animal.__init__(self) #super(Dog, self).__init__() super().__init__() print("init Dog class~") def run(self): print("dog run!")
测试Dog().run()运行结果如下
init Animal class~ init Dog class~ dog run!
子类实现了自己构造函数,就会调用自己的构造函数,python不会自动调用父类构造函数(与Java不一样),既然是继承,辣么就应该在子类的构造函数里面手动调用父类的构造函数。上述有三种方式。
若将Dog类改为:
class Dog(Animal): def run(self): print("dog run!")
这里Dog用的默认构造函数,测试Dog().run()运行结果如下
init Animal class~ dog run
子类没有定义自己的构造函数时,会调用父类的构造函数。如果有多个父类呢?
class Animal(object): def __init__(self): print("init Animal class~") def run(self): print("animal run!") class Father(object): def __init__(self): print("init Father class~") class Dog(Animal,Father): def run(self): print("dog run!")
测试Dog().run()运行结果如下
init Animal class~ dog run!
只会运行Animal的构造函数,若将Father放在第一个父类
class Dog(Father,Animal): def run(self): print("dog run!")
测试Dog().run()运行结果如下
init Father class~ dog run!
子类没有定义自己的构造函数时,只会调用第一个父类的构造函数。
2子类调用父类普通方法
class Animal(object): def run(self): print("animal run!") class Bird(Animal): def run(self): #Animal.run(self) #super(Bird, self).run() super().run()
测试Bird().run()运行结果如下:
animal run!
可以发现和调用构造方法的方式是一样的。
以上是关于python调用父类方法的三种方式(super调用和父类名调用)的主要内容,如果未能解决你的问题,请参考以下文章