博客
关于我
python3中类的继承
阅读量:319 次
发布时间:2019-03-04

本文共 1566 字,大约阅读时间需要 5 分钟。

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

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

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

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

#coding=utf-8class 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() #实例化Panda    print(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调用A        super().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

转载地址:http://bjpq.baihongyu.com/

你可能感兴趣的文章
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>