python有类似于C++的类继承, 例如:
class A: def __init__(self): print "init A Class" class B(A): def __init__(self): A() print"init B class"
结果:
init A Class
init B class
在上面的继承关系中 在初始化类B的时候需要在__init__函数中同时初始化A, 在单一继承的模式当中,这种方式有效切不会引起在错误。但是如果是多重继承的模式时, 比如
lass A(object): def __init__(self): print "init A Class" class B(A): def __init__(self): A.__init__(self) print"init B class" class C(A): def __init__(self): A.__init__(self) print"init C class" class D(B,C): def __init__(self): B.__init__(self) C.__init__(self) print "init D class" 结果: init A Class init B class init A Class init C class init D class
从结果中可以看到classA被初始化了两次, 这不是期望的结果,在实际的应用中会造成错误,super函数就是为了这种情况而存在的,防止父函数被多次初始化。例如:
class A(object):
def __init__(self):
print "init A Class"
class B(A):
def __init__(self):
print"init B class"
super(B, self).__init__()
class C(A):
def __init__(self):
print"init C class"
super(C, self).__init__()
class D(B,C):
def __init__(self):
print "init D class"
super(D, self).__init__()
class E(A):
def __init__(self):
print "init E class"
super(E, self).__init__()
class F(D,E):
def __init__(self):
print "init F class"
super(F, self).__init__()
F = F()
结果:
init F class
init D class
init B class
init C class
init E class
init A Class
在子类中初始化父对象是,利用super函数 就能够在多重继承的时候只初始化 父函数一次。有结果可以看出 构造函数的调用 顺序 是 F,D ,B,C, E, A, 类似与拓扑排序在在下一层的得子类没有全部初始化完成之前是不会调用 上一层的父类构造函数。