python类中super()和__init__()的区别
单继承时super()和__init__()实现的功能是类似的 class Base(object): def __init__(self): print 'Base create' class childA(Base): def __init__(self): print 'creat A ',Base.__init__(self) class childB(Base): def __init__(self): print 'creat B ',super(childB,self).__init__() base = Base() a = childA() b = childB() 输出结果: Base create creat A Base create creat B Base create 区别是使用super()继承时不用显式引用基类。 super()只能用于新式类中 把基类改为旧式类,即不继承任何基类 class Base(): def __init__(self): print 'Base create' 执行时,在初始化b时就会报错: super(childB,self).__init__() TypeError: must be type,not classobj super不是父类,而是继承顺序的下一个类 在多重继承时会涉及继承顺序,super()相当于返回继承顺序的下一个类,而不是父类,类似于这样的功能: def super(class_name,self): mro = self.__class__.mro() return mro[mro.index(class_name) + 1] mro()用来获得类的继承顺序。 例如: class Base(object): def __init__(self): print 'Base create' class childA(Base): def __init__(self): print 'enter A ' # Base.__init__(self) super(childA,self).__init__() print 'leave A' class childB(Base): def __init__(self): print 'enter B ' # Base.__init__(self) super(childB,self).__init__() print 'leave B' class childC(childA,childB): pass c = childC() print c.__class__.__mro__ 输出结果如下: enter A enter B Base create leave B leave A (<class '__main__.childC'>,<class '__main__.childA'>,<class '__main__.childB'>,<class '__main__.Base'>,<type 'object'>) supder和父类没有关联,因此执行顺序是A ―> B―>―>Base 执行过程相当于:初始化childC()时,先会去调用childA的构造方法中的 super(childA,self).__init__(), super(childA,self)返回当前类的继承顺序中childA后的一个类childB;然后再执行childB().__init()__,这样顺序执行下去。 在多重继承里,如果把childA()中的 super(childA,self).__init__() 换成Base.__init__(self),在执行时,继承childA后就会直接跳到Base类里,而略过了childB: enter A Base create leave A (<class '__main__.childC'>,<type 'object'>) 从super()方法可以看出,super()的第一个参数可以是继承链中任意一个类的名字, 如果是本身就会依次继承下一个类; 如果是继承链里之前的类便会无限递归下去; 如果是继承链里之后的类便会忽略继承链汇总本身和传入类之间的类; 比如将childA()中的super改为:super(childC,self).init(),程序就会无限递归下去。 如: File "C:/Users/Administrator/Desktop/crawler/learn.py",line 10,in __init__ super(childC,self).__init__() File "C:/Users/Administrator/Desktop/crawler/learn.py",self).__init__() RuntimeError: maximum recursion depth exceeded while calling a Python object super()可以避免重复调用 如果childA基础Base,childB继承childA和Base,如果childB需要调用Base的__init__()方法时,就会导致__init__()被执行两次: class Base(object): def __init__(self): print 'Base create' class childA(Base): def __init__(self): print 'enter A ' Base.__init__(self) print 'leave A' class childB(childA,Base): def __init__(self): childA.__init__(self) Base.__init__(self) b = childB() Base的__init__()方法被执行了两次 enter A Base create leave A Base create 使用super()是可避免重复调用 class Base(object): def __init__(self): print 'Base create' class childA(Base): def __init__(self): print 'enter A ' super(childA,self).__init__() print 'leave A' class childB(childA,Base): def __init__(self): super(childB,self).__init__() b = childB() print b.__class__.mro() enter A Base create leave A [<class '__main__.childB'>,<type 'object'>] 以上所述是小编给大家介绍的python类中super()和__init__()的区别,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- python – 是否可以在应用程序中使用X-AppEngine-Country
- PyCharm出现TabError: inconsistent use of tabs and space
- python – 如何在不丢失有效数字的情况下转换str中的浮点数
- python – scikit-learn:将任意函数应用为管道的一部分
- 在python日志记录中使用dictConfig,需要创建一个不同于在di
- python flask实现分页效果
- python实现随机森林random forest的原理及方法
- Python基础(1)
- python – Pandas – 替换列值
- 利用pandas进行大文件计数处理的方法