python3中类的继承以及self和super的区别详解

时间:2021-05-23

python中类的继承:

子类继承父类,及子类拥有了父类的 属性 和 方法。

python中类的初始化都是__init__()。所以父类和子类的初始化方式都是__init__(),但是如果子类初始化时没有这个函数,那么它便调用父类的__init__();如果实现了这个函数,就会覆盖父类的初始化函数。如果继承父类的__init__(),就需要在子类中显示调用这个函数。实现如下:

class Animal(object): def __init__(self): self.name = "我是父类" class Panda(Animal): def __init__(self): super().__init__() #使用super的方式来显示调用父类的__init__()函数 if __name__=="__main__": panda = Panda() #实例化Panda print(panda.name)我是父类 #输出可以看出使用了父类的初始化函数并有了name属性

子类也可以在初始化函数中定义自己的属性:

class Animal(object): def __init__(self): self.name = "我是父类" class Panda(Animal): def __init__(self): super().__init__() self.myname = "panda" if __name__=="__main__": panda = Panda() print(panda.myname)panda #子类自己的属性

self和super的区别:

★self是首先调用自身的方法如果自身没有再去父类中找;super是直接从父类中找方法

★self是类,super是预编译指令

★self class 和super calss的输出是一样的

class Animal(object): def __init__(self): self.name = "我是父类" def A(self): #父类中的A方法 print("父类的A方法") class Panda(Animal): def __init__(self): super().__init__() self.myname = "panda" def A(self): #子类中的A方法 print("子类的A方法") def B(self): self.A() #self调用A super().A() #super调用A if __name__=="__main__": panda = Panda() panda.B() #通过B函数来调用A方法,查看self和super的区别子类的A方法 #我们说过self是先从自身找方法,没有再去父类找父类的A方法 #而super则是直接从父类中找

如果子类中没有A方法那么会输出:

父类的A方法 #子类没有,self从父类中找父类的A方法

父类没有则会报错

以上则是python中继承的基础讲解,以及self和super的区别。类其实还是又很多复杂的地方,在使用过程会慢慢学习到,这里只是一个入门级的说明。

这篇python3中类的继承以及self和super的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章