参考:https://www.jianshu.com/p/45619cf50aa7
super()在Python中常用于类的继承,相比于直接调用继承,采用super()可以保证父类不被重复调用。
对于简单的调用父类:
class parent:
def fun1(self,message):
print(message)
class child(parent):
def fun2(self,message):
parent.fun1(self,message)
>>> child().fun2('hello')
hello
对于上面的例子,如果当父类的名字修改后,子类中相应的名字也要进行修改。为了避免该问题,可通过super()解决
class parent:
def fun1(self,message):
print(message)
class child(parent):
def fun2(self,message):
super(child,self).fun1(message)
>>> child().fun2('hello')
hello
上面两个例子中super(child,self).fun1(message)和parent.fun1(self,message)的表现一致,不过当涉及到多继承情况时,两种调用方式就会产生差异:
class A:
def __init__(self):
print('Enter A')
print('Leave A')
class B(A):
def __init__(self):
print('Enter B')
A.__init__(self)
print('Leave B')
class C(A):
def __init__(self):
print('Enter C')
A.__init__(self)
print('Leave C')
class D(B,C):
def __init__(self):
print ('Enter D')
B.__init__(self)
C.__init__(self)
print('Leave D')
>>> D()
Enter D
Enter B
Enter A
Leave A
Leave B
Enter C
Enter A
Leave A
Leave C
Leave D
下边是采用super()的情况,在super机制中可以保证公共父类仅被执行一次,且按照MRO(Method Resolution Order)进行:
class A:
def __init__(self):
print('Enter A')
print('Leave A')
class B(A):
def __init__(self):
print('Enter B')
super(B,self).__init__()
print('Leave B')
class C(A):
def __init__(self):
print('Enter C')
super(C,self).__init__()
print('Leave C')
class D(B,C):
def __init__(self):
print ('Enter D')
super(D,self).__init__()
print('Leave D')
>>> D()
Enter D
Enter B
Enter C
Enter A
Leave A
Leave C
Leave B
Leave D