Maison > développement back-end > Tutoriel Python > Comment la fonction « super() de Python fonctionne-t-elle avec l'héritage multiple et l'ordre de résolution de méthode (MRO) ?

Comment la fonction « super() de Python fonctionne-t-elle avec l'héritage multiple et l'ordre de résolution de méthode (MRO) ?

Barbara Streisand
Libérer: 2024-12-30 08:26:08
original
477 Les gens l'ont consulté

How Does Python's `super()` Function Work with Multiple Inheritance and Method Resolution Order (MRO)?

Super() de Python et héritage multiple

En Python, l'héritage multiple introduit des complexités lors de la détermination de la méthode parent à invoquer. La fonction super() joue un rôle crucial dans ce scénario, mais son comportement dépend de l'ordre de résolution de la méthode (MRO).

MRO et super()

La MRO définit l'ordre dans lequel les classes parent sont recherchées pour les attributs. Dans votre exemple :

class Third(First, Second):
    def __init__(self):
        super(Third, self).__init__()
        print "that's it"
Copier après la connexion

super(Third, self).__init__() appelle la méthode __init__() de la première classe du MRO. Dans ce cas, c'est First.

Choix de la méthode parent

Vous ne pouvez pas choisir explicitement la méthode parent à appeler à l'aide de super(). Le MRO dicte l'ordre de recherche, et super() fait toujours référence à la première classe dans cet ordre.

Exemple (héritage à chemin unique)

Dans votre exemple avec pas d'héritage croisé, le MRO est simple : [Troisième, Premier, Deuxième, objet]. Par conséquent, super(Third, self).__init__() appellera toujours First.__init__().

Exemple (héritage croisé)

Considérez le code suivant :

class First(object):
    def __init__(self):
        print "first"

class Second(First):
    def __init__(self):
        print "second"

class Third(First):
    def __init__(self):
        print "third"

class Fourth(Second, Third):
    def __init__(self):
        super(Fourth, self).__init__()
        print "that's it"
Copier après la connexion

Le MRO est désormais [Quatrième, Deuxième, Troisième, Premier, objet]. super(Fourth, self).__init__() appellera Second.__init__(), la première classe du MRO.

MRO ambigu

Si les chemins d'héritage交叉(par exemple, First hérité de Second), Python ne peut pas établir un MRO cohérent, ce qui entraîne un exception :

TypeError: Cannot create a consistent method resolution order (MRO) for bases Second, First
Copier après la connexion

Conclusion

super() est un outil puissant pour travailler avec l'héritage multiple. Cependant, comprendre le MRO est crucial pour prédire son comportement, car il dicte quelle méthode parent sera invoquée lors de l'utilisation de super().__init__().

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!

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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal