亚洲精品一二区_国产黄色片网站_99久久久成人国产精品_蜜臀网_国产精品一区二区三区免费_成人av中文字幕_91精品国产欧美一区二区成人

當前位置:首頁 > 嵌入式培訓 > 嵌入式學習 > 講師博文 > 堆和棧的區別

堆和棧的區別 時間:2018-08-09      來源:未知

對于編程初學者來說會接觸到一些難以理解的名稱,比如堆(heap)、棧(stack)、堆棧(stack)等。初學開發過程中往往讓人混淆不清。今天我們來談談堆和棧的具體區別,來幫助初學者理清思路。

堆和棧的區別一直都是永恒的話題,為此我也查了很多的資料,以防自己的理解錯誤,而給他人造成理解偏差。

先從簡單的一個例子引出堆和棧:

void function(){

int *p = (int *)malloc(10*sizeof(int));

}

這是C語言開發學習過程中,必不可免要學習的知識,動態分配一塊空間,空間在堆區大小是40字節(32位系統中)。而定義的指針變量p是局部變量(在棧區中 占用4字節空間),用來存放剛剛前面動態分配的空間的首地址。可以看出,在這一句代碼中同時包含了棧和堆,如圖1所示。 

圖1堆和棧

我們從以下幾個方面比較一下堆和棧:

(1)存儲內容不同

棧:在函數調用時,棧中存放的是函數中(底下是函數調用后的下一條指令)各個參數(局部變量)。

堆:一般是在堆的頭部用一個字節存放堆的大小。堆中的具體內容有程序員安排。

(2)管理方式上不同

棧:由系統自動分配空間,同時系統自動釋放空間。 例如,聲明在函數中一個局部變量 int b; 系統自動在棧中為b開辟空間,當對應的生存周期結束后棧空間自動釋放。

堆:需要程序員手動申請并且手動釋放,并指明大小,在C語言中malloc函數申請,釋放free函數,在C++中 new和delete實現。

(3)空間大小不同

棧:獲取空間較小。在Windows下,一般大小是1M或2M,當剩余棧空間不足時,分配失敗overflow。

堆:獲得空間根據系統的有效虛擬內存有關,比較靈活,比較大。

(4)能否產生碎片不同

棧:不會產生碎片,空間連續。

堆:采用的是鏈表的存儲方式,會產生碎片。

(5)生長方向不同

棧: 向低地址擴展的數據結構,是一塊連續的內存的區域。

堆: 向高地址擴展的數據結構,是不連續的內存區域。這是由于系統是用鏈表來存儲的空閑內存地址的,自然是不連續的,而鏈表的遍歷方向是由低地址向高地址。

(6)分配方式不同

棧:有2種分配方式:靜態分配和動態分配,靜態由編譯器完成,例如局部變量;動態由alloca函數實現,并且編譯器會進行釋放。

堆: 都是動態分配的,沒有靜態分配的堆。

(7)分配效率不同

棧:由系統自動分配,速度較快。但程序員是無法控制的。

堆:由new分配的內存,一般速度比較慢,而且容易產生內存碎片,不過用起來方便。

以上是棧和堆幾個方面的不同,希望通過上面的資料可以幫助初學者分清堆和棧。

上一篇:新ARM處理器架構

下一篇:分頻器設計原理淺析

熱點文章推薦
華清學員就業榜單
高薪學員經驗分享
熱點新聞推薦
前臺專線:010-82525158 企業培訓洽談專線:010-82525379 院校合作洽談專線:010-82525379 Copyright © 2004-2022 北京華清遠見科技集團有限公司 版權所有 ,京ICP備16055225號-5京公海網安備11010802025203號

回到頂部

主站蜘蛛池模板: 欧美亚洲欧美日韩中文二区 | 韩国三级hd中文字幕好大 | 国产精品每日更新在线观看 | 天天看天天摸天天操 | 色天天综合色天天碰 | 一级久久| 午夜视频十八嗯嗯啊免费 | 亚洲妇人成熟性成熟网站 | 四虎海外影库www4hu | 欧美三级在线看中文字幕 | 国产日韩视频在线 | 色吧在线视频 | 国产靠逼视频 | 欧美精品免费看 | 欧美亚洲国产精品久久高清 | 天天成人| 日本色免费 | 国产成人综合洲欧美在线 | 欧美在线中文字幕高清的 | 免费观看a级完整视频 | 久久这里只有精品66 | 国产成人午夜性a一级毛片 国产成人香蕉 | 日韩欧美在线观看视频一区二区 | 色偷偷人人澡人人爽人人模 | 日本内谢69xxxx免费播放 | 久久精品国产曰本波多野结衣 | 久久狠狠婷婷丁香香蕉 | 狠狠干伊人 | 三级网站免费看 | 日本xxx20xxxx30xxxx日本 | 久久综合九色综合欧美播 | 午夜在线亚洲男人午在线 | 天天看天天爽 | 欧美婷婷六月丁香综合色 | 久在线观看视频 | 中国在线观看www视频 | 玖玖在线精品 | 国产日本欧美亚洲精品视 | 性xxxx视频播放免费 | 国产网红主播在线视频观看 | 日本jizz中国 |