1)首先,写法不一样:
class A:
pass
class B(object):
pass
2)在多继承中,新式类采用广度优先搜索,而旧式类是采用深度优先搜索。
3)新式类更符合OOP编程思想,统一了python中的类型机制。
讲下自己的理解,有如下程序
class A():
def __init__(self):
pass
def save(self):
print("This is from A")
class B(A):
def __init__(self):
pass
class C(A):
def __init__(self):
pass
def save(self):
print("This is from C")
class D(B,C):
def __init__(self):
pass
fun = D()
fun.save()
经典类的答案: This is from A
新式类的答案: This is from C
且看此图!按照这句话来说,新式类采用广度优先搜索,而旧式类是采用深度优先搜索
新式类顺序DBCA:D无save()->B无save()->C存在save()
旧式类顺序DABC:D无save()->A存在save()
倘若这里Class B 增加方法save(),则显示This is from B。

换一个角度来说,从调用角度来看,B在C之前,那肯定比C先被访问吧?访问了B如果有save()那一定不会访问下去吧,没有就接着访问,到底了就回溯,这个思路很符合程序函数调用栈思想吧。
因此,如果在B添加了save()函数后,更换Class C中 ,B,C的顺序为C,B。可以得到This is from C。
本文解析Python中新旧式类在多继承下的不同搜索策略,以及如何影响方法调用。通过实例说明新式类的广度优先搜索原理,解释为何在特定情况下B类save()优先于C类。
542

被折叠的 条评论
为什么被折叠?



