Heim > Backend-Entwicklung > Python-Tutorial > Erstellt das Aufteilen einer Liste in Python Kopien der zugrunde liegenden Objekte?

Erstellt das Aufteilen einer Liste in Python Kopien der zugrunde liegenden Objekte?

Susan Sarandon
Freigeben: 2024-11-08 14:55:02
Original
1082 Leute haben es durchsucht

Does Slicing a List in Python Create Copies of the Underlying Objects?

Aufteilen einer Liste ohne Generieren einer Kopie in Python

Das Problem:
Generieren Sie bei einer gegebenen Liste von Ganzzahlen alle Unterlisten der Bilden Sie L[k:] für k in [0, len(L)-1] effizient, ohne Kopien zu erstellen.

Die Antwort:
Das Aufteilen einer Liste in Python führt nicht zu einer Generierung Kopien der zugrunde liegenden Objekte, nur Verweise auf sie.

Referenzkopie verstehen

Um dies zu demonstrieren, betrachten Sie drei ganzzahlige Objekte mit demselben Wert:

a = [1000 + 1, 1000 + 1, 1000 + 1]
Nach dem Login kopieren

Sie haben unterschiedliche Objekt-IDs, die darauf hinweisen, dass es sich um separate Objekte handelt:

map(id, a)  # returns [140502922988976, 140502922988952, 140502922988928]
Nach dem Login kopieren

Das Aufteilen dieser Objekte führt zu neuen Listenobjekten mit denselben Referenzen, was zeigt, dass keine neuen Objekte erstellt wurden:

b = a[1:3]
map(id, b)  # returns [140502922988952, 140502922988928]
Nach dem Login kopieren

Dieses Verhalten gilt sowohl für unveränderliche (z. B. Ganzzahlen) als auch veränderliche (z. B. Listen) Werte.

Überlegungen zum Overhead

Während das Slicing keine neuen Objekte generiert, verursacht es dennoch einen gewissen Speicher-Overhead zum Kopieren von Referenzen und zum Pflegen von Listenmetadaten. Beispielsweise hat eine Liste mit N Elementen einen Speicheraufwand von 72 Byte.

Ansichten und Numpy-Arrays

Wenn die Speicheroptimierung von entscheidender Bedeutung ist, sollten Sie Numpy-Arrays anstelle von Listen als Slicing-Numpy-Arrays verwenden teilt den Speicher zwischen dem Slice und dem ursprünglichen Array. Dieser Ansatz erfordert jedoch eine sorgfältige Handhabung, um unbeabsichtigte Änderungen zu vermeiden.

Fazit

Slicing-Listen in Python ist eine effiziente Operation, die keine Kopien der zugrunde liegenden Objekte generiert. Dieses Verhalten sollte bei der Betrachtung von Leistungsoptimierungen berücksichtigt werden.

Das obige ist der detaillierte Inhalt vonErstellt das Aufteilen einer Liste in Python Kopien der zugrunde liegenden Objekte?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage