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