Maison >développement back-end >Tutoriel Python >Comment la fonction « super() » de Python gère-t-elle plusieurs héritages et ordres de résolution de méthodes (MRO) ?

Comment la fonction « super() » de Python gère-t-elle plusieurs héritages et ordres de résolution de méthodes (MRO) ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-29 19:28:12208parcourir

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

Super() de Python avec héritage multiple

En Python, l'héritage multiple implique une classe héritant de plusieurs classes parents. Lors de l'utilisation de la fonction super() dans de tels scénarios, il devient crucial de comprendre son comportement.

super() dans l'héritage multiple

super() sert principalement à deux fins :

  1. Pour accéder aux attributs et méthodes de la classe parent immédiate.
  2. Pour résoudre les conflits de méthodes lorsque la classe enfant en a plusieurs classes parents.

Dans l'extrait de code donné :

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

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

class Third(First, Second):
    def __init__(self):
        super(Third, self).__init__()
        print("that's it")

Lorsqu'un troisième objet est instancié, ce qui suit se produit :

  • super(Third , self).__init__() appelle First.__init__(self) car First est la première classe du MRO (Method Resolution) de la troisième classe Order).
  • First.__init__(self) imprime "first."
  • Third.__init__(self) puis imprime "c'est tout."

MRO ambigus

Cependant, lorsque la chaîne d'héritage devient plus complexe, il peut y avoir une ambiguïté dans déterminer le MRO. Cela se produit lorsqu'une classe enfant hérite de plusieurs classes héritant de la même classe de base. Python génère une erreur dans de tels cas.

Par exemple, considérons 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")

Lorsque vous tentez de créer une classe qui hérite à la fois de Second et Third, Python génère une TypeError en raison à un MRO ambigu. L'ordre des classes parentes dans la liste d'héritage est important et doit être cohérent dans toute la base de code.

Conclusion

La fonction super() de Python est un outil puissant pour gérer héritage multiple. En comprenant son comportement, vous pouvez résoudre efficacement les conflits de méthodes et maintenir une hiérarchie de classes claire.

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:
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