经典类中,属性搜索处理对所有路径深度优先,直到继承树的顶端,然后从左到右进行;
新式类中,属性搜索处理沿着树层级、以更加广度优先的方式进行。
新式类的优点:可以避免重复搜索超类。
直接上代码说明:
# Python 2
class Super:
attr = 0
class A(Super):
pass
class B(Super):
attr = 2
class C(A, B):
pass
ci = C()
print ci.attr # 输出 0
# Python 3
class Super:
attr = 0
class A(Super):
pass
class B(Super):
attr = 2
class C(A, B):
pass
ci = C()
print(ci.attr) # 输出 2
参考文献:
- 《Python 学习手册(第 4 版)》 - P760 。

本文探讨了Python中经典类与新式类在属性搜索上的不同处理方式。经典类采用深度优先搜索,而新式类则采用更高效的广度优先搜索,避免重复搜索超类。通过代码示例,展示了不同搜索策略对属性查找的影响。
543

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



