首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >python中的super是什么?

python中的super是什么?

作者头像
DechinPhy
发布2022-05-10 10:11:30
发布2022-05-10 10:11:30
3.1K0
举报
文章被收录于专栏:Dechin的专栏Dechin的专栏

技术背景

python中的super,名为超类,可以简单的理解为执行父类的__init__函数。由于在python中不论是一对一的继承,还是一子类继承多个父类,都会涉及到执行的先后顺序的问题。那么本文就着重看下super的具体作用。

案例测试

通过设计这样一个案例,我们可以明确super的前后逻辑关系:先定义一个父类initial,在这个父类中有参数值param和函数func,然后用子类new来继承父类initial。继承之后,在子类的__init__函数中super执行的前后去打印参数值param和函数func的返回值,相关代码如下所示:

代码语言:javascript
复制
# 定义父类
class initial(object):
    def __init__(self):
        print ('This print is from initial object')
        # 定义父类参数
        self.param = 3

    # 定义父类函数
    def func(self):
        return 1

# 定义子类
class new(initial):
    def __init__(self):
        print ('This print is from new object')
        # 打印子类函数值
        print (self.func())
        # 执行父类初始化函数
        super(new, self).__init__()
        # 打印父类参数值
        print(self.param)
        self.param = 4

    # 定义子类函数
    def func(self):
        return 2

if __name__ == '__main__':
    new()

代码的执行结果如下所示:

代码语言:javascript
复制
This print is from new object
2
This print is from initial object
3

结果分析

首先我们注意到,父类initial中的__init__函数内的打印语句,是在super之后才输出的,这说明了,super函数是在执行父类的初始化操作。那么如果没有执行supernew子类对initial父类的继承体现在哪里呢?答案就是父类的成员函数,比如这样的一个案例:

代码语言:javascript
复制
class initial(object):
    def __init__(self):
        print ('This print is from initial object')
        self.param = 3
    def func(self):
        return 1

class new(initial):
    def __init__(self):
        print ('This print is from new object')
        print (self.func())
        super(new, self).__init__()
        print(self.param)
        self.param = 4

if __name__ == '__main__':
    new()

其实就是删掉了子类中重载的成员函数,那么得到的结果如下:

代码语言:javascript
复制
This print is from new object
1
This print is from initial object
3

可以发现在执行super之前就可以打印父类的func函数的函数值。所以python中继承的逻辑是这样的:

initial.func()\\ \Downarrow\\ new.\_\_init\_\_()\\ \Downarrow\\ new.func()/new.param\\ \Downarrow\\ super()\\ \Downarrow\\ initial.\_\_init\_\_()/initial.param\\ \Downarrow\\ new.\_\_init\_\_()/new.param

也正是因为只有执行了super才能初始化父类中的成员变量,因此如果在super之前是无法访问父类的成员变量的。

总结概要

本文通过一个python的实际案例的设计,来讲解python面向对象的技术——类的继承中必用的super函数的逻辑。其实我们可以把python中类的继承理解成这样的一个过程:当我们在括号中明确了父类时,其实已经引用了父类的成员函数,但是并没有执行父类的初始化函数。在执行子类的初始化函数的同时,会检查是否重载了父类的成员函数,如果重载则会直接覆盖。而只有在执行了super之后,才相当于执行了父类的初始化函数,此时才可以访问父类的成员变量。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 技术背景
  • 案例测试
    • 结果分析
  • 总结概要
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档