前言
數(shù)據(jù)結構中,堆(heap)與棧(stack)是兩個常見的數(shù)據(jù)結構,它們的存在都是為了優(yōu)化內存,提高使用效率,各有特點,理解二者的定義、用法與區(qū)別,能夠利用堆與棧解決很多實際問題。
棧:由操作系統(tǒng)(編譯器)自動分配釋放 ,存放函數(shù)的參數(shù)值,局部變量的值等
堆:一般由程序員分配釋放, 若程序員不釋放,程序結束時由OS回收
內存分配圖
通過下圖了解常用的堆棧內存分配和增長方向:
增長方向及原因
堆(heap)的增長方向是向上增長,即低地址向高地址增長。
棧(stack)的增長方向是向下增長,即高地址向低地址增長。
堆和棧的增長方向不一致可以讓空閑的內存能最大程度的被使用。
能夠確定棧的起始地址。
從內存分配圖來看,假設棧(stack)的增長方向也是向上增長,那么??臻g的起始位置就要事先固定下來,在棧和堆的總內存大小確定的時候,一個分配多了。另一個分配少了,在不同程序中內存的使用情況不同,有些棧用的多,有些堆用的多。
所以就很有可能出現(xiàn)這種情況:一個程序因為棧溢出而崩潰的時候,其實它還有大量閑置的堆空間沒有被使用,但是我們卻無法使用這些閑置的堆空間。所以最好的辦法就是讓堆和棧一個向上漲,一個向下漲,這樣它們就可以最大程度地共用這塊剩余的地址空間,達到利用率的最大化!
并且在棧和堆的總內存大小已經(jīng)確定的情況下,不用考慮程序中堆棧的不同使用情況下就能先確定棧的起始地址。
當然,現(xiàn)在的有些芯片在編譯時可以指定棧的增長方向,不過常用的還是向下增長。
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
相關推薦
請問下差動放大器通常是應用在什么場合?
發(fā)表于 09-19 06:35
各個全局變量和靜態(tài)變量.堆的生長方向,都是向上的.在程序里面,所有的內存分為:堆+棧. 只是他們各自的起始地址和增長方向不同,他們沒有一個固
發(fā)表于 02-10 10:28
STM32的堆棧增長方向是從高地址往低地址增長的,這樣的話棧底應該是高地址咯。而下圖的棧底卻是低地址,查了很多資料,感覺都很矛盾。像INT8UOSTaskCreateExt 的第三個參
發(fā)表于 04-20 04:36
的原子哥視頻,發(fā)現(xiàn)視頻里這塊兒沒講,UCOS里的堆棧方向是向上增長,而32里是向下[摘自原子哥],這樣會不會沖突呢?我所嘗試的理解:這兩個堆棧占用的是互不相關的兩個存儲空間////@發(fā)燒友 @mygod @Admin @偉好好學習
發(fā)表于 04-23 03:51
棧 stack 空間堆 heap 空間存儲函數(shù)參數(shù)和局部變量,所需空間由系統(tǒng)自動分配,回收也由系統(tǒng)管理,無需人工干預存儲動態(tài)分配的內存塊,分配和釋放空間均由程序員控制,有可能產(chǎn)生內存泄漏嚴格后進先出
發(fā)表于 11-03 08:54
在回答完進程的虛擬地址空間布局之后(上一篇),面試官可能抓住堆和棧深入展開。堆和棧的區(qū)別①管理方式:棧由編譯器自動管理;
發(fā)表于 12-22 07:26
,程序執(zhí)行過程中棧溢出,極大可能的影響程序、系統(tǒng)的穩(wěn)定,嚴重時會造成程序、系統(tǒng)的崩潰,所以堆棧溢出檢測十分重要且必要。什么是堆,什么是棧堆和棧
發(fā)表于 12-22 06:09
放大電路的靜態(tài)工作點通常是指?
發(fā)表于 01-27 13:37
四軸的姿態(tài)進行采樣用通常是用什么濾波算法進行濾波的
發(fā)表于 10-09 06:42
在減少EMI問題時,大多數(shù)同軸電纜表現(xiàn)相同。它們都是普通電流的良好天線,可以輻射并通過FCC認證類型測試。電纜不是EMC測試失敗的主要來源,通常是連接器。 如果有任何凈電流或常見電流一根電纜,通過
發(fā)表于 11-10 14:58
?373次閱讀
光的傳播通常是互換的,這意味著光在一個方向上傳播的軌跡,與在相反方向上傳播光的軌跡相同。
發(fā)表于 03-27 16:52
?2134次閱讀
電子發(fā)燒友網(wǎng)為你提供我們習以為常的IIC通常是什么樣子?資料下載的電子資料下載,更有其他相關的電路圖、源代碼、課件教程、中文資料、英文資料、參考設計、用戶指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
發(fā)表于 03-29 08:40
?6次下載
在一般的編譯系統(tǒng)中,堆內存的分配方向和棧內存是相反的。當棧內存從高地址向低地址增長的時候,
發(fā)表于 07-05 17:58
?9970次閱讀
畢竟堆棧也就是內存,自然就可以通過堆棧的分配過程取出所分配的內存地址來比較判斷,而C語言可以方便的訪問內存,也就比較容易判斷當前處理器中堆棧指針的增長方向了。
發(fā)表于 07-28 11:23
?2468次閱讀
傳統(tǒng)封裝通常是指先將晶片切割成單個芯片再進行封裝的工藝形式,主要包含SIP、DIP、SOP、SOT、TO、QFP、QFN、DFN、BGA 等封裝形式。
發(fā)表于 02-15 17:37
?4901次閱讀
評論