前言
數(shù)據(jù)結(jié)構(gòu)中,堆(heap)與棧(stack)是兩個(gè)常見的數(shù)據(jù)結(jié)構(gòu),它們的存在都是為了優(yōu)化內(nèi)存,提高使用效率,各有特點(diǎn),理解二者的定義、用法與區(qū)別,能夠利用堆與棧解決很多實(shí)際問題。
棧:由操作系統(tǒng)(編譯器)自動(dòng)分配釋放 ,存放函數(shù)的參數(shù)值,局部變量的值等
堆:一般由程序員分配釋放, 若程序員不釋放,程序結(jié)束時(shí)由OS回收
內(nèi)存分配圖
通過下圖了解常用的堆棧內(nèi)存分配和增長方向:
增長方向及原因
堆(heap)的增長方向是向上增長,即低地址向高地址增長。
棧(stack)的增長方向是向下增長,即高地址向低地址增長。
堆和棧的增長方向不一致可以讓空閑的內(nèi)存能最大程度的被使用。
能夠確定棧的起始地址。
從內(nèi)存分配圖來看,假設(shè)棧(stack)的增長方向也是向上增長,那么棧空間的起始位置就要事先固定下來,在棧和堆的總內(nèi)存大小確定的時(shí)候,一個(gè)分配多了。另一個(gè)分配少了,在不同程序中內(nèi)存的使用情況不同,有些棧用的多,有些堆用的多。
所以就很有可能出現(xiàn)這種情況:一個(gè)程序因?yàn)闂R绯龆罎⒌臅r(shí)候,其實(shí)它還有大量閑置的堆空間沒有被使用,但是我們卻無法使用這些閑置的堆空間。所以最好的辦法就是讓堆和棧一個(gè)向上漲,一個(gè)向下漲,這樣它們就可以最大程度地共用這塊剩余的地址空間,達(dá)到利用率的最大化!
并且在棧和堆的總內(nèi)存大小已經(jīng)確定的情況下,不用考慮程序中堆棧的不同使用情況下就能先確定棧的起始地址。
當(dāng)然,現(xiàn)在的有些芯片在編譯時(shí)可以指定棧的增長方向,不過常用的還是向下增長。
-
內(nèi)存
+關(guān)注
關(guān)注
8文章
3109瀏覽量
74999 -
數(shù)據(jù)結(jié)構(gòu)
+關(guān)注
關(guān)注
3文章
573瀏覽量
40604 -
STACK
+關(guān)注
關(guān)注
0文章
14瀏覽量
2988
發(fā)布評(píng)論請(qǐng)先 登錄
差動(dòng)放大器通常是應(yīng)用在什么場(chǎng)合?
STM32 大小端模式 與 堆棧及其增長方向分析
STM32堆棧增長方向問題
UCOSIII任務(wù)堆棧和STM32堆棧增長方向是否一致?
MCU堆空間和棧空間的相關(guān)資料分享
堆和棧的區(qū)別是什么
什么是堆?什么是棧
四軸的姿態(tài)進(jìn)行采樣用通常是用什么濾波算法進(jìn)行濾波的?
連接器通常是EMI問題
光在一個(gè)方向上傳播的軌跡與在相反方向上傳播的軌跡相同嗎
我們習(xí)以為常的IIC通常是什么樣子?資料下載

什么是堆內(nèi)存?堆內(nèi)存是如何分配的?
用C語言如何判斷棧的增長方向呢

評(píng)論