python3中类的继承

用简单的一句话来理解:继承,这样理解就对了,你的就是我的,但是我的还是我的,但是你有我也有的,我就不稀罕你的,所以调用了父类的时候,self就是我,而不是你

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

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

情况1:子类没有__init__函数,那么直接执行父类的__init__函数

#coding=utf-8
class Animal(object):def __init__(self):self.name='I am the super class'
class Panda(Animal):def ok():print("I am the son class!!!")
if __name__=='__main__':
panda=Panda()
print(panda.name)
a = Panda()
#子类是没有构造函数的,那么直接调用父类的构造函数
print(a.name)

情况2:

class Animal(object):def __init__(self):self.name = "我是父类"class Panda(Animal):def __init__(self):super().__init__() #使用super的方式来显示调用父类的__init__()函数# 也可以使用第二种super初始化的方式super(Panda, self).__init__()
if __name__=="__main__":panda = Panda() #实例化Pandaprint(panda.name)

output1:

我是父类

self和super的区别:

  • self是首先调用自身的方法如果自身没有再去父类中找;super是直接从父类中找方法
  • self是类,super是预编译指令
  • self class 和super calss的输出是一样的

input3

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调用Asuper().A()  #super调用Aif __name__=="__main__":panda = Panda()panda.B()   #通过B函数来调用A方法,查看self和super的区别

output3

子类的A方法	#我们说过self是先从自身找方法,没有再去父类找
父类的A方法	#而super则是直接从父类中找

参考自: https://www.jb51.net/article/163991.htm


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部