python中的类分为经典类(旧式类)和新式类。python的新式类是2.2版本为了统一类和实例引进来的。python
在Python2.x中默认都是经典类,只有显式继承了object的才是新式类。
以下所示:算法
# 新式类,显示继承object class A(object): pass # 经典类 class A(): pass # 经典类 class A: pass
在python3.x中取消了经典类,默认都是新式类,而且新式类不须要显式的继承object对象。以下所示,这三种写法均可以,并没有区别:python3.x
# 第一种 class A(object): pass # 第二种 class A(): pass # 第三种 class A: pass
MRO
(method resolution order 基类搜索顺序)算法是采用深度优先搜索,而新式类的MRO
算法采用C3算法广度优先搜索。新式类和经典类最大的不一样在于继承搜索的顺序发生了改变。
经典类采用深度优先搜索,也就是先深刻继承树左侧查找,而后再返回,开始查找右侧:函数
class A: def show(self): print("From A") class B(A): def show(self): print("From B") class C(A): def show(self): print("From C") class D(B, C): pass d = D() d.show() # From B
新式类采用广度优先搜索,先在水平方向查找,再向上查找:code
class A(object): def show(self): print("From A") class B(A): def show(self): print("From B") class C(A): def show(self): print("From C") class D(B, C): pass d = D() d.show() # From C