MRO(Method resolution order)是python用来解析方法调用顺序的,mro中记录了一个类的所有基类的类类型序列,super不是简单地调用基类的方法,而是按照MRO中的顺序来调用类的方法。
使用super()时,应该在所有类中使用,否则就可能发生有的类构造函数没有调用的情况。
#!/usr/bin/python
# -*- coding: utf-8 -*-
class A(object):
def __init__(self):
print ‘A __init__‘
super(A, self).__init__()
print ‘leave A‘
class C(object):
def __init__(self):
print ‘C __init__‘
super(C, self).__init__()
print ‘leave C‘
class B(A,C):
def __init__(self):
print ‘B __init__‘
super(B, self).__init__()
print ‘leave B‘
class D(B):
def __init__(self):
print ‘D __init__‘
super(D, self).__init__()
print ‘leave D‘
if __name__ == ‘__main__‘:
D()
输出为:
D __init__
B __init__
A __init__
C __init__
leave C
leave A
leave B
leave D
编译过程:super(D,self)查找D的父类,根据广度优先算法依次查找super(类名,self)的父类。
顺便说一下 经典类和新式类的区别?
(1)在python2.x中,从object继承得来的类称为新式类(如class A(object))不从object继承得来的类称为经典类(如class A())
(2) 新式类对象可以直接通过__class__属性获取自身类型:type
(3)继承搜索的顺序发生了改变,经典类多继承时属性搜索顺序: 先深入继承树左侧,再返回,开始找右侧(即深度优先搜索);新式类多继承属性搜索顺序: 先水平搜索,然后再向上移动(即广度优先搜索)。
如下图所示:
原文:http://www.cnblogs.com/wspblog/p/4279949.html