什么是內(nèi)存碎片?
在嵌入式系統(tǒng)中,內(nèi)存是十分有限而且是十分珍貴的,用一塊內(nèi)存就少了一塊內(nèi)存,而在分配中隨著內(nèi)存不斷被分配和釋放,整個系統(tǒng)內(nèi)存區(qū)域會產(chǎn)生越來越多的碎片。
因為在使用過程中,申請了一些內(nèi)存,其中一些釋放了,導(dǎo)致內(nèi)存空間中存在一些小的內(nèi)存塊,它們地址不連續(xù),不能夠作為一整塊的大內(nèi)存分配出去,所以一定會在某個時間,系統(tǒng)已經(jīng)無法分配到合適的內(nèi)存了,導(dǎo)致系統(tǒng)癱瘓。
系統(tǒng)中實際是還有內(nèi)存的,但是因為小塊的內(nèi)存的地址不連續(xù),導(dǎo)致無法分配成功。
內(nèi)存碎片產(chǎn)生過程,如下圖所示:
過程說明如下:
(1)、此時內(nèi)存堆還沒有經(jīng)過任何操作,為全新的。
(2)、此時經(jīng)過第一次內(nèi)存分配,一共分出去了 4 塊內(nèi)存塊,大小分別為 80B、80B、10B 和100B。
(3)、有些應(yīng)用使用完內(nèi)存,進行了釋放,從左往右第一個 80B 和后面的 10B 這兩個內(nèi)存塊就是釋放的內(nèi)存。如果此時有個應(yīng)用需要 50B 的內(nèi)存,那么它可以從兩個地方來獲取到,一個是最前面的還沒被分配過的剩余內(nèi)存塊,另一個就是剛剛釋放出來的 80B 的內(nèi)存塊。但是很明顯,剛剛釋放出來的這個 10B 的內(nèi)存塊就沒法用了,除非此時有另外一個應(yīng)用所需要的內(nèi)存小于 10B。
(4)、經(jīng)過很多次的申請和釋放以后,內(nèi)存塊被不斷分割、最終導(dǎo)致大量很小的內(nèi)存塊。也就是圖中 80B 和 50B 這兩個內(nèi)存塊之間的小內(nèi)存塊,這些內(nèi)存塊由于太小導(dǎo)致大多數(shù)應(yīng)用無法使用,這些沒法使用的內(nèi)存塊就淪為了內(nèi)存碎片。
內(nèi)存碎片是內(nèi)存管理算法重點解決的一個問題,否則的話會導(dǎo)致實際可用的內(nèi)存越來越少,最終應(yīng)用程序因為分配不到合適的內(nèi)存而崩潰,所以我們需要一個優(yōu)良的內(nèi)存分配算法來避免這種情況的出現(xiàn)。
*博客內(nèi)容為網(wǎng)友個人發(fā)布,僅代表博主個人觀點,如有侵權(quán)請聯(lián)系工作人員刪除。