Python 中的 MRO 无法按预期工作

s9527

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

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__.

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章