python3中super()参数意义和用法

python3中super()参数意义和用法

转载自 Python面向对象中super用法与MRO机制

转载自: Python中super的用法【转载】

python3中super()参数意义和用法寻踪(个人理解)

https://blog.csdn.net/qq_39418396/article/details/97649164

我们知道super()是为了类继承之后为了调用被重写的父类方法而使用,而且它应该还能通过参数精地准指出用的是哪一代父类的方法。然而对其内部的机理和它的传参上还是有些疑惑的。

参考了博文https://www.cnblogs.com/yanlin-10/p/10272338.html

帖子https://stackoverflow.com/questions/576169/understanding-python-super-with-init-methods/576183?r=SearchResults#576183

以及python官方文档 https://docs.python.org/2/library/functions.html#super之后进行了总结,

个人觉得super()的正确传参只有两种,super(类名,对象名)和super(类名1,类名2)

--------->注意,在python3中,在定义类方法中直接调用不含参数的super(),也不会报错,解释的时候自动传入默认参数:

class A(Base):
    def __init__(self):
        super().__init__()  # 等同于 super(A, self).__init__()
        print('A.__init__')

参数必须满足的条件:

扫描二维码关注公众号,回复: 10520906 查看本文章

1)、super(cls,obj)即传入类名+对象名:

obj对象必须是cls类的对象(cls子类的对象当然也是cls类的对象) ,记作 type(obj) <= cls

2)、super(cls1,cls2)即传入两个类名:

cls2必须是cls1的子类或本身,记作cls2<=cls1

super起到代理作用,通过传入的两个类参数,定位你希望调用的 继承链中X父类中重写的同名方法,即super(cls1,cls2).fun是通过类cls1,类cls2,定位类X,并使用X类中的fun(self, …)方法

两者的区别:

  1. super(cls,obj).classfunc 是个’method’,即视作类方法,obj作为X.classfunc的第一个self参数自动传入(隐式传入)

2)super(cls,cls).classfunc是个’function’,即视作独立的普通函数,其原型中的第一个self参数也需要手动写入(显示传入)

https://stackoverflow.com/questions/576169/understanding-python-super-with-init-methods/576183?r=SearchResults#576183

上面讨论了python2的捆绑与非捆绑方法到Python3独立函数与“包裹方法“的演变

分清了这两种用法的区别,super()的关键就是如何通过cls,cls2定位到类X

如果是单继承,直接找cls的上一级父类,如果是多继承甚至是钻石形状继承,则是通过类的mro(method resolution order)列表的下一项进行判断,比较复杂, 暂不讨论。

22

Python中的super()方法设计目的是用来解决多重继承时父类的查找问题,所以在单重继承中用不用 super 都没关系;但是,使用 super() 是一个好的习惯。一般我们在子类中需要调用父类的方法时才会这么用。

super()的好处就是可以避免直接使用父类的名字.主要用于多重继承,如下:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述在这里插入图片描述
MainWindow.setCentralWidget(self.centralWidget)
在这里插入图片描述
QtCore.QMetaObject.connectSlotsByName(MainWindow)

发布了824 篇原创文章 · 获赞 313 · 访问量 105万+

猜你喜欢

转载自blog.csdn.net/wowocpp/article/details/105223224