棧和堆的區別

2021-06-29 00:07:00 字數 472 閱讀 1897

1、申請方式和**方式不同

不知道你是否有點明白了。

堆和棧的第乙個區別就是申請方式不同:棧(英文名稱是stack)是系統自動分配空間的,例如我們定義乙個 char a;系統會自動在棧上為其開闢空間。而堆(英文名稱是heap)則是程式設計師根據需要自己申請的空間,例如malloc(10);開闢十個位元組的空間。

由於棧上的空間是自動分配自動**的,所以棧上的資料的生存週期只是在函式的執行過程中,執行後就釋放掉,不可以再訪問。而堆上的資料只要程式設計師不釋放空間,就一直可以訪問到,不過缺點是一旦忘記釋放會造成記憶體洩露。

2.申請效率的比較

根據第0點和第1點可知。

:由系統自動分配,速度較快。但程式設計師是無法控制的。

:是由new分配的記憶體,一般速度比較慢,而且容易產生記憶體碎片,不過用起來最方便。

堆和棧區別

一 預備知識 程式的記憶體分配 乙個由c c 編譯的程式占用的記憶體分為以下幾個部分 1 棧區 stack 由編譯器自動分配釋放 存放函式的引數值,區域性變數的值等。其 操作方式類似於資料結構中的棧。2 堆區 heap 一般由程式設計師分配釋放,若程式設計師不釋放,程式結束時可能由os回 收 注意它...

堆和棧區別

管理方式 棧由編譯器自動管理 堆由程式設計師控制,使用方便,但易產生記憶體洩露。生長方向 棧向低位址擴充套件 即 向下生長 是連續的記憶體區域 堆向高位址擴充套件 即 向上生長 是不連續的記憶體區域。這是由於系統用鍊錶來儲存空閒記憶體位址,自然不連續,而鍊錶從低位址向高位址遍歷。空間大小 棧頂位址和...

堆和棧區別

一 預備知識 程式的記憶體分配 乙個由c c 編譯的程式占用的記憶體分為以下幾個部分 1 棧區 stack 由編譯器自動分配釋放 存放函式的引數值,區域性變數的值等。其 操作方式類似於資料結構中的棧。2 堆區 heap 一般由程式設計師分配釋放,若程式設計師不釋放,程式結束時可能由os回 收 注意它...