Почему Python мульти-наследовать не вызывает один родитель - PullRequest
0 голосов
/ 05 ноября 2019

Я просто играю в Python MRO и обнаружил что-то странное для множественного наследования. Код:

class A():
    def __init__(self):
        print('enter A')
        print('leave A')


class B(A):
    def __init__(self):
        print('enter B')
        super().__init__()
        print('leave B')


class C():   
    def __init__(self):
        print('enter C')
        super().__init__()
        print('leave C')


class D(B, C):
    def __init__(self):
        print('enter D')
        super().__init__()
        print('leave D')


print(D.__mro__)
d = D()

Результат:

(<class '__main__.D'>, <class '__main__.B'>, <class '__main__.A'>, <class '__main__.C'>, <class 'object'>)
enter D
enter B
enter A
leave A
leave B
leave D

Был вызван класс C, почему не было напечатано "enter C"?

1 Ответ

0 голосов
/ 05 ноября 2019

В Python наследование - это просто способ сказать «если вы не нашли такого метода в моем классе, найдите мой родительский класс» с поиском слева направо, если у нас множественное наследование.

В большинстве случаев в простейших случаях вы можете думать о поиске атрибутов, унаследованных от родительского класса, как о первой глубине, слева направо, а не о поиске дважды в одном и том же классе, где есть перекрытие виерархия. Таким образом, если атрибут не найден в DerivedClassName, он ищется в Base1, затем (рекурсивно) в базовых классах Base1, и, если он там не был найден, он ищется в Base2 и т. Д.

Python doc

TLDR;в классе D super().__init__() можно найти в классе B, поэтому Python не выполняет поиск в классе C

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...