Ist ein „eingefrorenes Diktat“ in Python möglich?
Das Konzept eines „eingefrorenen Diktats“ war ein Diskussionsthema innerhalb der Python-Community. Während Python kein integriertes Frozendict bereitstellt, sind mehrere Lösungen entstanden, um den Bedarf an einem unveränderlichen, hashbaren Wörterbuch zu decken.
Ein häufiger Grund für den Wunsch nach einem Frozendict ist das Auswendiglernen von Funktionsaufrufen mit unbekannten Argumenten. Ein typischer Ansatz besteht darin, die Argumente mithilfe von tuple(sorted(kwargs.items())) in ein Tupel umzuwandeln und sich dabei auf die Sortierstabilität für die Hash-Tabellensuche zu verlassen.
Für einen umfassenderen Ansatz betrachten Sie die folgende FrozenDict-Klasse:
import collections
class FrozenDict(collections.Mapping):
...
Diese Klasse stellt Methoden für Iteration, Längenbestimmung, Elementabruf und Hash-Berechnung bereit und stellt sicher, dass sie sich wie ein Standardwörterbuch verhält und Hashing unterstützt.
In der Praxis arbeitet FrozenDict effizient :
x = FrozenDict(a=1, b=2)
y = FrozenDict(a=1, b=2)
print(x is y, x == y, x == {'a': 1, 'b': 2})
d = {x: 'foo'}
print(d[y]) # 'foo'
Durch die Bereitstellung einer benutzerdefinierten Implementierung ermöglicht FrozenDict unveränderliche, hashbare Wörterbücher in Python und erweitert so die Möglichkeiten für die Objektverarbeitung und Speicheroptimierung.
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3