python3中类的继承以及self和super的区别详解
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的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持【听图阁-专注于Python设计】。