Method Resolution Order (MRO) Unterschiede zwischen Legacy- und New-Style-Klassen
New-Style-Klassen in Python führten zu einer bedeutenden Änderung in der Method Resolution Order (MRO) im Vergleich zu Legacy-Klassen. Während das bereitgestellte Beispiel die MRO-Auflösung für Klassen neuen Stils korrekt demonstriert, wollen wir uns mit den subtilen Unterschieden befassen, die die beiden Ansätze unterscheiden.
Der Hauptunterschied tritt zutage, wenn eine Vorfahrenklasse mehrmals in der „naiven“ Tiefe vorkommt. erste Beschlussfassung. Betrachten Sie den folgenden Fall der „Diamantvererbung“:
class A: x = 'a' class B(A): pass class C(A): x = 'c' class D(B, C): pass
Bei Verwendung von Legacy-Klassen wäre die Auflösungsreihenfolge: D – B – A – C – A. In dieser Reihenfolge wird A zuerst angetroffen, was zur Folge hat Definition von 'x' wird durch die nachfolgende Definition in C ausgeblendet.
D.x => 'a'
Klassen neuen Stils übernehmen jedoch eine überarbeitete MRO:
D.__mro__ = (<class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <type 'object'>)
Diese Reihenfolge stellt sicher, dass Vorfahrenklassen angezeigt werden nur einmal und schließlich alle ihre Unterklassen. Folglich haben Überschreibungen wie die C-Modifikation von „x“ Vorrang.
D.x => 'c'
Durch die Vermeidung des mehrfachen Auftretens von Vorfahrenklassen in der Auflösungsreihenfolge beseitigt dieser Ansatz Mehrdeutigkeiten und gewährleistet intuitives Verhalten in komplexen Vererbungshierarchien. Aus diesem Grund sollten Klassen alten Stils generell zugunsten von Klassen neuen Stils vermieden werden, insbesondere wenn es um Mehrfachvererbung und rautenartige Muster geht.
Das obige ist der detaillierte Inhalt vonWie unterscheidet sich die Method Resolution Order (MRO) zwischen älteren und neuen Klassen in Python?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!