(摘抄自https://www.zhihu.com/question/51836333)性能
處理內存碎片的方法:使用基於頁面的內存管理方式。優化
內存碎片是如何出現的?操作系統
當使用最原始的標記分配方法分配內存時,系統須要維護一個簡單的內存信息表:翻譯
當程序申請一個長度爲3的內存空間後:3d
當程序再申請一個長度爲2,以及長度爲4的內存空間後:blog
此時,只剩1個可用空間。若是這時程序再來申請長度大於1的空間,就申請不了,也就是內存不夠。ip
如今,釋放掉ID=2的空間:內存
咱們發現,如今可用內存空間爲3,可是,這3個空閒空間,並非連續的。因此,若是程序如今申請長度爲3的內存空間,一樣會申請不了,會出現內存不夠。業界把這種狀況,稱之爲【內存碎片】。get
基於頁面的內存管理方式:內存管理
首先,把物理內存,按照某種尺寸,進行平均分割。好比我如今以2個內存單位,來分割內存,也就是每兩個連續的內存空間,組成一個內存頁:
接着,系統一樣須要維護一個內存信息表:
如今,程序申請長度爲3的內存空間,不過因爲如今申請的最小單位爲頁面,而一個頁面的長度爲2,所以如今須要申請2個頁面,也就是4個內存空間。你看,這就浪費了1個內存空間。
以上就是基本原理,實際系統中會作很是多的優化。目前各類主流操做系統都是分頁的方式,所以你不須要太關心碎片。
這個話題再延伸下去,就是一個程序內部的局部內存池了。不過這是另外一個問題,喜歡的話能夠深究一下。 做者:匿名用戶 連接:https://www.zhihu.com/question/51836333/answer/145693402 來源:知乎 著做權歸做者全部。商業轉載請聯繫做者得到受權,非商業轉載請註明出處。