Heim >häufiges Problem >Was sind die Unterschiede zwischen Heap und Stack?

Was sind die Unterschiede zwischen Heap und Stack?

青灯夜游
青灯夜游Original
2019-05-05 13:10:02114917Durchsuche

Die Unterschiede zwischen Heap und Stack sind: 1. Unterschied in der Speicherplatzzuordnung; 2. Unterschied in der Caching-Methode; 3. Unterschied in der Datenstruktur; Der Heap-Speicherplatz wird im Allgemeinen vom Programmierer zugewiesen und freigegeben, und der Stapelspeicher wird automatisch vom Betriebssystem (Compiler) zugewiesen und freigegeben. Der Stack verwendet den Cache der ersten Ebene und der Heap den Cache der zweiten Ebene.

Was sind die Unterschiede zwischen Heap und Stack?

Was ist der Unterschied zwischen Heap und Stack

Unterschied in der Stapelplatzzuordnung

Stack (Betriebssystem): Wird vom Betriebssystem (Compiler) automatisch zugewiesen und freigegeben und speichert Funktionsparameterwerte, lokale Variablenwerte usw. Es funktioniert wie ein Stapel in einer Datenstruktur.

Heap (Betriebssystem): Wird im Allgemeinen vom Programmierer zugewiesen und freigegeben. Wenn der Programmierer ihn nicht freigibt, kann er vom Betriebssystem recycelt werden, wenn das Programm endet. Die Zuweisungsmethode ähnelt einer verknüpften Liste.

2. Unterschiede in den Stack-Caching-Methoden

Der Stack verwendet einen Cache der ersten Ebene. Sie befinden sich normalerweise im Speicherbereich, wenn sie aufgerufen werden, und werden sofort freigegeben nachdem der Anruf beendet ist.

Der Heap wird im Cache der zweiten Ebene gespeichert und der Lebenszyklus wird durch den Garbage-Collection-Algorithmus der virtuellen Maschine bestimmt (Sobald es zu einem verwaisten Objekt wird, kann es nicht recycelt werden). Daher ist die Geschwindigkeit beim Aufrufen dieser Objekte relativ gering.

3. Unterschiede in der Stapeldatenstruktur

Heap (Datenstruktur): Der Heap kann als Baum betrachtet werden, wie zum Beispiel: Heap-Sortierung.

Stapel (Datenstruktur): Eine First-in-Last-out-Datenstruktur.

Das obige ist der detaillierte Inhalt vonWas sind die Unterschiede zwischen Heap und Stack?. 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