python - Python 中的 MRO 未按预期工作

标签 python multiple-inheritance method-resolution-order

我找到了一个多重继承的示例,但不明白它的行为方式。

class Printable:
    """A mixin class for creating a __str__ method that prints
    a sequence object. Assumes that the type difines __getitem__."""

    def lef_bracket(self):
        return type(self).__name__ + "["

    def right_bracket(self):
        return "]"

    def __str__(self):
        result = self.lef_bracket()
        for i in range(len(self)-1):
            result += str(self[i]) + ", "
        if len(self) > 0:
            result += str(self[-1])
        return result + self.right_bracket()

此脚本存储在 printable.py 中,因此类 Printable 的使用方式如下:

>>> from printable import *
>>> class MySeq(list, Printable):
...     pass
... 
>>> my_seq = MySeq([1,2,3])
>>> print(my_seq)
MySeq[1, 2, 3]

我的问题是,为什么__str__方法继承自Printable类而不是list类,而方法解析顺序MySeq 是:

>>> MySeq.__mro__
(<class '__main__.MySeq'>, <class 'list'>, <class 'printable.Printable'>, <class 'object'>)

Printable 的文档字符串中,我注意到“mixin”这个词。为什么在这种情况下我们将其称为 mixin 类?

最佳答案

list 未定义 __str__ 方法:

>>> '__str__' in list.__dict__
False

因为它没有定义这样的方法,所以 MRO 中的下一个类可以提供它。对于普通的 list 对象,那就是 object.__str__:

>>> list.__mro__
(<class 'list'>, <class 'object'>)
>>> list.__str__ is object.__dict__['__str__']
True

但是因为Printable混入其中,所以它被列在之前object:

>>> MySeq.__mro__
(<class '__main__.MySeq'>, <class 'list'>, <class '__main__.Printable'>, <class 'object'>)
>>> MySeq.__str__ is Printable.__dict__['__str__']
True

混合类是设计为添加到类层次结构中以与其他基类一起工作的类。 Printable 是一个混合项,因为它需要其他东西实现 __getitem__

关于python - Python 中的 MRO 未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43963641/

相关文章:

java - Scala 选择在签名冲突的情况下实现哪个特征?

c++ - 多继承中vtable c++中保存的重写虚方法在哪里

c++ - 多重继承的重载解析

python - MRO、super 在 python 中如何工作

c# - 从方法签名中删除通用参数

python - Python中的Lookup Chain和MRO有什么关系?

python - 将原始图像与可能不需要原始图像的编辑图像进行比较的另一种方法

python - 带有扭曲 python HTTPS 服务器的反向代理

python - 组合线性同余发生器

python - 根据 URL 包含的最高参数过滤 URL 的 Python 列表