Schnelle Einschlussprüfungen in Python 3 range()-Objekt
Die Funktion range() in Python 3 scheint rechenintensiv zu sein, wie es scheint um die Mitgliedschaft in einem breiten Spektrum zu prüfen. Es arbeitet jedoch auf eine optimierte Art und Weise, die dieser Erwartung widerspricht.
Unter der Haube verwendet range() ein intelligentes Sequenzobjekt, das eine Vorabberechnung seines gesamten Inhalts vermeidet. Stattdessen speichert es die Start-, Stopp- und Schrittwerte und berechnet die Zahlen bei Bedarf während der Iteration.
Entscheidend ist, dass das range()-Objekt den Hook contains implementiert, um die Mitgliedschaft effizient zu berechnen, ohne sie zu scannen potenzielle Werte. Diese nahezu konstante Zeitoperation vermeidet die Notwendigkeit, jede Ganzzahl im Bereich zu durchlaufen.
Betrachten Sie zur Veranschaulichung eine benutzerdefinierte Bereichsimplementierung:
class my_range: # Constructor with start, stop, and step values def __init__(self, start, stop, step): self.start = start self.stop = stop self.step = step # Generator for iterating through the range def __iter__(self): current = self.start if self.step < 0: while current > self.stop: yield current current += self.step else: while current < self.stop: yield current current += self.step # ... (additional methods for length, indexing, etc.) ... # Optimized containment check def __contains__(self, num): # Calculate if num is in the range return (num - self.start) % self.step == 0
Dieser benutzerdefinierten Implementierung fehlen mehrere Funktionen von Python range()-Objekt, das die optimierte Natur des letzteren demonstriert. Das range()-Objekt verwaltet den Speicher effizient und führt Einschlussprüfungen ohne großen Rechenaufwand durch, was es zu einem robusten und schnellen Werkzeug für die Arbeit mit Bereichen macht.
Das obige ist der detaillierte Inhalt vonWie erreicht das „range()'-Objekt von Python 3 schnelle Eindämmungsprüfungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!