Heim >Backend-Entwicklung >Python-Tutorial >Beschreibung des Speicherorts des Integer-Objektspeichers in Python

Beschreibung des Speicherorts des Integer-Objektspeichers in Python

高洛峰
高洛峰Original
2017-03-16 17:09:161207Durchsuche

In Python sind die Speicherorte, an denen ganzzahlige Objekte gespeichert werden, unterschiedlich, einige sind vorab zugewiesener Speicher und werden immer im Speicher gespeichert, während andere dazu verwendet werden, Speicherplatz freizugeben.


Der Grund dafür ist der folgende Code:

a = 5
b = 5
a is b # True
a = 500
b = 500
a is b # False

Wie aus dem obigen Code ersichtlich ist, ist die Ganzzahl immer 5 existiert, aber die Ganzzahl 500 existiert nicht immer


Welche Ganzzahlen haben also vorab zugewiesene Speicheradressen?

a, b, c = 0, 0, 0
i = 0
while a is b:
    i += 1
    a, b = int(str(i)), int(str(i))
else:
    print(i) # 打印 257

Wie wir aus dem oben Gesagten wissen, werden nicht negative ganze Zahlen kleiner oder gleich 256 (2**8) immer gespeichert (dh ihre Speicheradressen werden im Voraus zugewiesen und müssen später nicht zugewiesen werden) )

a = -1
b = -1
a is b # False

Und negative Zahlen werden nicht im Voraus geöffnet.


Das obige ist der detaillierte Inhalt vonBeschreibung des Speicherorts des Integer-Objektspeichers in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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