Maison > développement back-end > Tutoriel Python > Héritage diamant dans l'héritage multiple Python

Héritage diamant dans l'héritage multiple Python

angryTom
Libérer: 2020-02-12 12:45:31
avant
4236 Les gens l'ont consulté

Cet article présente l'utilisation de l'héritage diamant dans l'héritage multiple Python. J'espère qu'il sera utile aux amis qui apprennent Python !

Héritage diamant dans l'héritage multiple Python

L'héritage est un moyen important de programmation orientée objet. Grâce à l'héritage, les sous-classes peuvent étendre les fonctions des classes parentes. En Python, une classe peut hériter de plusieurs classes parents. C'est ce qu'on appelle l'Héritage Multiple de Python (Héritage Multiple).

Syntaxe

class SubclassName(BaseClass1, BaseClass2, BaseClass3, ...):
    pass
Copier après la connexion

Héritage Diamond

Apprentissage recommandé : Tutoriel vidéo Python

Héritage à plusieurs niveaux Lorsqu'elle est utilisée avec l'héritage multiple, des relations d'héritage complexes apparaîtront, telles que l'héritage multiple.

Parmi eux, l'héritage du diamant apparaîtra. Comme indiqué ci-dessous. Héritage diamant dans lhéritage multiple Python

Dans cette structure, il existe une confusion concernant l'ordre d'appel. Lequel des éléments suivants est l'ordre d'appel ?

  • D-> A->C (profondeur en premier)
  • D->B->C->A (largeur en premier)

Répondons à cette question.

Par exemple :

class A():
    def __init__(self):
        print('init A...')
        print('end A...')

class B(A):
    def __init__(self):
        print('init B...')
        A.__init__(self)
        print('end B...')

class C(A):
    def __init__(self):
        print('init C...')
        A.__init__(self)
        print('end C...')

class D(B, C):
    def __init__(self):
        print('init D...')
        B.__init__(self)
        C.__init__(self)
        print('end D...')

if __name__ == '__main__':
    D()
Copier après la connexion

Résultat de sortie

init D...
init B...
init A...
end A...
end B...
init C...
init A...
end A...
end C...
end D...
Copier après la connexion

À partir du résultat de sortie, la séquence d'appel est : D->B->A-> ;C-> ;UN. On peut voir que B et C héritent conjointement de A et que A est appelé deux fois. Il n’est pas nécessaire d’appeler A deux fois.

En fait, les causes profondes des problèmes ci-dessus sont toutes liées au MRO (Method Résolution Order) est également appelé Method Résolution Order, qui est principalement utilisé. pour déterminer la résolution lors d'un héritage multiple. De quelle classe provient l'attribut ? Il utilise un algorithme appelé C3 L'idée de base est que utilise la largeur d'abord et de gauche à droite en partant du principe d'éviter le. la même classe étant appelée plusieurs fois les principes pour trouver les propriétés et méthodes requises.

Alors, comment empêcher qu'une méthode de la classe parent de niveau supérieur soit appelée plusieurs fois ? Super() est nécessaire à ce stade. Super est essentiellement une classe qui enregistre les informations MRO en interne, car. l'algorithme C3 garantit que la même classe ne sera recherchée qu'une seule fois, évitant ainsi que la méthode de la classe parent de niveau supérieur soit exécutée plusieurs fois, le code ci-dessus peut être modifié en :

class A():
    def __init__(self):
        print('init A...')
        print('end A...')

class B(A):
    def __init__(self):
        print('init B...')
        super(B, self).__init__()
        print('end B...')

class C(A):
    def __init__(self):
        print('init C...')
        super(C, self).__init__()
        print('end C...')

class D(B, C):
    def __init__(self):
        print('init D...')
        super(D, self).__init__()
        print('end D...')

if __name__ == '__main__':
    D()
Copier après la connexion

Résultat de sortie :

init D...
init B...
init C...
init A...
end A...
end C...
end B...
end D...
Copier après la connexion
On peut voir que la séquence d'appel à ce moment est D->B->C->A. Autrement dit, la méthode de traversée est

largeur d'abord.

Contenu supplémentaire

Les classes Python sont divisées en deux types, l'un est appelé

classe classique et l'autre est appelé classe de nouveau style. Les deux prennent en charge l’héritage multiple, mais l’ordre d’héritage est différent.

  • Nouvelle classe de style : Une classe héritée de l'objet. (Par exemple : classe A (objet)), héritée à l'aide d'une recherche en largeur d'abord (c'est-à-dire une recherche horizontale d'abord, puis une recherche vers le haut).
  • Classe classique : Une classe qui n'hérite pas d'un objet. (Par exemple : classe A()), héritez en utilisant la méthode de recherche en profondeur d'abord (c'est-à-dire, allez d'abord profondément dans le côté gauche de l'arbre d'héritage, puis revenez, puis trouvez le côté droit).
Il existe deux types de classes dans Python 2.x : les classes classiques et les nouvelles classes.

Python3.x regorge de classes de nouveau style.

Pour plus de tutoriels sur Python, veuillez faire attention à la colonne

Tutoriel Python.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:cnblogs.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal