实现功能
super()函数的调用顺序是按照方法解析顺序(Method Resolution Order, MRO)来确定的。MRO 是一个确定继承顺序的算法,它使用 C3 线性化算法来避免潜在的方法冲突。Python会根据继承顺序自动计算 MRO,我们只需要使用 super() 来调用父类的方法即可。
假设A、B、C、D四个类分别是一下的继承关系:
实现代码
# 实例一:
class A(object):
def __init__(self):
print("class ---- A ----")
class B(A):
def __init__(self):
print("class ---- B ----")
super(B, self).__init__()
class C(A):
def __init__(self):
print("class ---- C ----")
super(C, self).__init__()
# 实例一
class D(B, C):
def __init__(self):
print(D.__mro__)
print("class ---- D ----")
super(D, self).__init__()
d = D()
'''
#输出结果:
class ---- D ----
class ---- B ----
class ---- C ----
class ---- A ----
'''
# 实例二
class D(B, C):
def __init__(self):
print("class ---- D ----")
super(B, self).__init__()
d = D()
'''
#输出结果:
class ---- D ----
class ---- C ----
class ---- A ----
'''
# 实例三
class D(B, C):
def __init__(self):
print("class ---- D ----")
super(C, self).__init__()
d = D()
'''
# 输出结果:
class ---- D ----
class ---- A ----
'''
实现效果
-
__mro__是一个元组,类D的__mro__顺序是 D -> B -> C -> A -> object。
-
实例一中,在类D中调用super()函数时传入的第一个参数是D,那么super()函数就会在__mro__ 里从D的上一级开始查找,它的上一级是B, 那么super(D, self).__init__() 就调用B的__init__()函数,B的__init__()函数里又调用了B的super()函数,super(B, self).__init__(),那就从B的上一级再开始查找,B的上一级是C, 以此类推,然后是A,最后是object。于是实例一也就解释清楚了。
-
实例二中,类D的super() 方法第一个参数传入的是B ,那么根据__mro__顺序开始查找,B的上一级是C,C的上一级是A,所以实例二的打印顺序是 D - > C -> A
-
实例三读者可以自行理解验证。
写在后面
本人读研期间发表5篇SCI数据挖掘相关论文,现在某研究院从事数据算法相关科研工作,对Python有一定认知和理解,会结合自身科研实践经历不定期分享关于python、机器学习、深度学习等基础知识与应用案例。
致力于只做原创,以最简单的方式理解和学习,关注我一起交流成长。
1、邀请三个朋友关注本订阅号或2、分享/在看任意订阅号的三篇文章即可在后台联系我获取相关数据集和源码。
2、关注“数据杂坛”公众号,点击“领资料”即可免费领取资料书籍。
3、如果对本文有疑问,或者有论文指导的相关需求,点击“联系我”添加作者微信直接交流。