python中多重继承与super函数用法


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, 类似与拓扑排序在在下一层的得子类没有全部初始化完成之前是不会调用 上一层的父类构造函数。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM