当在“天真”的深度优先方法中,同一祖先类出现多次时,旧类与新类的解析顺序之间的关键区别就出现了:例如,考虑“钻石继承”情况:
>>> class A: x = 'a'... >>> class B(A): pass... >>> class C(A): x = 'c'... >>> class D(B, C): pass... >>> D.x'a'
在这里,是传统样式,解析顺序为D-B-A-C-A:因此,在查找Dx时,A是解析顺序中解决它的第一个基数,从而将定义隐藏在C中。
>>> class A(object): x = 'a'... >>> class B(A): pass... >>> class C(A): x = 'c'... >>> class D(B, C): pass... >>> D.x'c'>>>
在这里,新式的顺序是:
>>> D.__mro__(<class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <type 'object'>)
与A被迫来到分辨率顺序只有一次,毕竟它的子类,从而使覆盖(即尺寸材料的的覆盖x)实际上有效地工作。
这是应避免使用旧式类的原因之一:“菱形”模式的多重继承对它们不起作用,而对新式则可行。



