旧式类和新式类之间的方法解析顺序 (MRO) 差异
Python 中的新式类在与遗留类相比的方法解析顺序 (MRO)。虽然提供的示例正确演示了新型类的 MRO 解析,但让我们深入研究区分这两种方法的细微差别。
当祖先类在“朴素”深度中多次出现时,关键区别就会出现 -第一个决议顺序。考虑以下“钻石继承”情况:
class A: x = 'a' class B(A): pass class C(A): x = 'c' class D(B, C): pass
使用遗留类,解析顺序为:D - B - A - C - A。按照此顺序,首先遇到 A,从而导致'x' 的定义被 C 中的后续定义隐藏。
D.x => 'a'
但是,新式类采用修订后的 MRO:
D.__mro__ = (<class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <type 'object'>)
此顺序确保祖先类出现仅一次且毕竟是它们的子类。因此,像 C 对 'x' 的修改这样的覆盖优先。
D.x => 'c'
通过避免在解析顺序中多次出现祖先类,这种方法消除了歧义并确保了复杂继承层次结构中的直观行为。这就是为什么通常应该避免使用旧式类而选择新式类,特别是在处理多重继承和类菱形模式时。
以上是Python 中传统类和新式类的方法解析顺序 (MRO) 有何不同?的详细内容。更多信息请关注PHP中文网其他相关文章!