python3中super()参数意义和用法
转载自 Python面向对象中super用法与MRO机制
转载自: Python中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__')
参数必须满足的条件:
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, …)方法
两者的区别:
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)列表的下一项进行判断,比较复杂, 暂不讨论。
Python中的super()方法设计目的是用来解决多重继承时父类的查找问题,所以在单重继承中用不用 super 都没关系;但是,使用 super() 是一个好的习惯。一般我们在子类中需要调用父类的方法时才会这么用。
super()的好处就是可以避免直接使用父类的名字.主要用于多重继承,如下:
MainWindow.setCentralWidget(self.centralWidget)
QtCore.QMetaObject.connectSlotsByName(MainWindow)