c語言中堆和棧的區別?詳細解答,淺析C語言中堆和棧的區別

2021-04-20 16:51:37 字數 2802 閱讀 6472

1樓:匿名使用者

棧是先入後出、後入先出的儲存區域,對作業系統來說管理比較簡單,只需要記版錄棧底和當前棧

權頂的位置即可,一般用於保護現場。比如呼叫函式時,呼叫點pc位址被壓入堆疊、函式引數被壓入棧,在函式呼叫結束時會被彈出堆疊指令丟棄或被返回語句利用。

堆是提供給當前程式執行時刻開設緩衝區(如使用malloc函式、new等),由應用程式主動管理(釋放用free和delete),比如printf語句就需要利用堆來臨時儲存輸出資訊。另外由子程式中開設的非靜態變數一般存放在堆中,退出子程式後被自動釋放。

2樓:匿名使用者

堆:指的是認為用**動態申請的記憶體空間,所有手動釋放。例如:malloc的記憶體

棧:就是當變數生命週期結束,由系統自動**記憶體。

**c語言中堆和棧的區別

c語言中堆和棧的區別

3樓:匿名使用者

資料結構裡堆和棧,原理差不多都是先進後出,但是堆一般是乙個二叉樹,是非線性,比如堆排序。棧往往是線性。

c語言裡堆和棧是作業系統對記憶體管理實現的兩個不同部分。

棧空間是作業系統自己管理,分配,釋放也是作業系統做。普通區域性變數都存在棧裡。

堆區的空間是使用者自己分配管理,比如每一次malloc必須自己free。要不然作業系統不會幫你釋放。

c語言還有乙個**段,這個區域程式執行後不可寫,一般用來儲存常量。

4樓:匿名使用者

一、程式的記憶體分配

乙個由c/c++編譯的程式佔用的記憶體分為以下幾個部分1、棧區(stack)— 由編譯器自動分配釋放 ,存放函式的引數值,區域性變數的值等。其操作方式類似於資料結構中的棧。

2、堆區(heap) — 一般由程式設計師分配釋放, 若程式設計師不釋放,程式結束時可能由os** 。注意它與資料結構中的堆是兩回事,分配方式倒是類似於連結串列,呵呵。

3、全域性區(靜態區)(static)—全域性變數和靜態變數的儲存是放在一塊的,初始化的全域性變數和靜態變數在一塊區域, 未初始化的全域性變數和未初始化的靜態變數在相鄰的另一塊區域。 - 程式結束後有系統釋放

4、文字常量區—常量字串就是放在這裡的。 程式結束後由系統釋放5、程式**區—存放函式體的二進位制**。

二、例子程式

//main.cpp

int a = 0; //全域性初始化區

char *p1; //全域性未初始化區

main()

5樓:匿名使用者

壓根沒有關係,棧是順序結構,堆是樹形結構,兩個資料結構各有用途

c語言中記憶體堆和棧的區別是什麼?

6樓:匿名使用者

給你寫個小例子說明吧,乙個小函式。

void testfunction()

上面函式中,變數a的記憶體就在棧中,a的生命週期只在大括號內,出了testfunction的大括號這塊棧空間就被釋放了。

而上面函式通過呼叫malloc函式給pa分配了3*sizeof(int)個位元組長度的記憶體,這段記憶體就在堆中。

即使出了testfunction函式的大括號,這段記憶體也依然被佔用著。不過,由於pa這個指標的生命週期 出了大括號就結束了,所以無法再用pa來引用這塊記憶體了。

上面只是舉例,真正程式設計不會這樣寫,這樣pa指向的記憶體就無法被釋放了,造成記憶體洩露。

7樓:裘**郯妝

堆記憶體是用malloc或new分配的記憶體空間,棧是用關鍵字定義出變數的記憶體空間.有些時候必須用堆記憶體,如:連結串列.堆最好是用來存放大資料.而棧本身就小,但速度快.

8樓:餘長青威書

比較簡單的理解是堆要靠自己管理,棧是系統幫你管理的,一般堆空間很大適合放大型的資料結構,棧空間有限一般僅僅放是函式的引數和內部的臨時變數

c語言中記憶體堆和棧的區別

9樓:匿名使用者

函式體內的自動變數佔用棧空間,呼叫函式時使用棧空間傳遞引數返回值等資訊;使用malloc()類的函式分配的空間佔用堆

10樓:泰燦融朗麗

給你寫個小例子說明吧,乙個小函式。

void

testfunction()

上面函式中,變數a的記憶體就在棧中,a的生命週期只在大括號內,出了testfunction的大括號這塊棧空間就被釋放了。

而上面函式通過呼叫malloc函式給pa分配了3*sizeof(int)個位元組長度的記憶體,這段記憶體就在堆中。

即使出了testfunction函式的大括號,這段記憶體也依然被佔用著。不過,由於pa這個指標的生命週期

出了大括號就結束了,所以無法再用pa來引用這塊記憶體了。

上面只是舉例,真正程式設計不會這樣寫,這樣pa指向的記憶體就無法被釋放了,造成記憶體洩露。

c語言裡棧和堆的區別整理

11樓:匿名使用者

棧區。由編譯器自動分配釋放,存放函式的引數值、區域性變數的值等。其操作方式類似於資料結構中的棧。

每當乙個函式被呼叫,該函式返回位址和一些關於呼叫的資訊,比如某些暫存器的內容,被儲存到棧區。然後這個被呼叫的函式再為它的自動變數和臨時變數在棧區上分配空間,這就是c實現函式遞迴呼叫的方法。每執行一次遞迴函式呼叫,乙個新的棧框架就會被使用,這樣這個新例項棧裡的變數就不會和該函式的另乙個例項棧裡面的變數混淆。

堆區(heap)。用於動態記憶體分配。堆在記憶體中位於bss區和棧區之間。一般由程式設計師分配和釋放,若程式設計師不釋放,程式結束時有可能由os**。

c語言中的棧和堆是什麼?

在c中什麼是退棧??C語言中,什麼是棧,什麼是堆

退棧就是指把乙個資料從棧裡刪除,也就是從棧頂取出乙個元素 該資料不用儲存,如是出棧操作則該資料要儲存 同時棧頂指標減一。由於 棧 往往和 堆疊 聯絡在一起,所以我就一起解釋這兩個概念 在計算機領域,堆疊是乙個不容忽視的概念,但是很多人甚至是計算機專業的人也沒有明確堆疊其實是兩種資料結構。堆疊都是一種...

c語言中與的區別,C語言中 與 的區別

區別如復下表 擴充套件資料具體區別制的例子 bai1 c 語言輸入輸出du printf a d,b d zhi,a,b scanf d d d a,b,c 2 vb 語言的輸入輸出 inputbox x 輸入 x 的值dao print x x 而且,這兩種運算子,還分為字首運算和字尾運算 如 i...

在c語言中pd和x的區別,在c語言中p,d和x的區別是什麼?

x不要前導0,也就說前面的0會被自動去掉也可以用 08x列印出來跟 p一樣的 實際上是一樣的,不過 p是專用來處理指標的吧,而 x對列印的資料都可以,感覺差不多,就是用 p的時候列印出來都是8個資料的 計算機儲存的都是2進製,當然也可以用 d列印位址,列印指標,指標就是用來存放位址的 位址需要符號麼...