python3中类的继承以及self和super的区别详解
python中类的继承:
子类继承父类,及子类拥有了父类的属性和方法。
python中类的初始化都是__init__()。所以父类和子类的初始化方式都是__init__(),但是如果子类初始化时没有这个函数,那么它便调用父类的__init__();如果实现了这个函数,就会覆盖父类的初始化函数。如果继承父类的__init__(),就需要在子类中显示调用这个函数。实现如下:
classAnimal(object): def__init__(self): self.name="我是父类" classPanda(Animal): def__init__(self): super().__init__()#使用super的方式来显示调用父类的__init__()函数 if__name__=="__main__": panda=Panda()#实例化Panda print(panda.name)
我是父类#输出可以看出使用了父类的初始化函数并有了name属性
子类也可以在初始化函数中定义自己的属性:
classAnimal(object): def__init__(self): self.name="我是父类" classPanda(Animal): def__init__(self): super().__init__() self.myname="panda" if__name__=="__main__": panda=Panda() print(panda.myname)
panda#子类自己的属性
self和super的区别:
★self是首先调用自身的方法如果自身没有再去父类中找;super是直接从父类中找方法
★self是类,super是预编译指令
★selfclass和supercalss的输出是一样的
classAnimal(object): def__init__(self): self.name="我是父类" defA(self):#父类中的A方法 print("父类的A方法") classPanda(Animal): def__init__(self): super().__init__() self.myname="panda" defA(self):#子类中的A方法 print("子类的A方法") defB(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的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。