內(nèi)存管理

歷史

在早期的計算機(jī)棚壁,程序是直接運行在物理內(nèi)存上的,也就是說继榆,程序所訪問的地址都是物理內(nèi)存巾表。但是我們往往需要同時運行多個程序,所以就有一個很明顯的問題如何把計算機(jī)上有限的物理內(nèi)存分配給多個程序使用略吨?

舉個例子

假如我們計算機(jī)有128M內(nèi)存集币,現(xiàn)在:

  • 程序A需要10M內(nèi)存
  • 程序B需要100M內(nèi)存
  • 程序C需要20M內(nèi)存

如果我們需要同時運行A和B,那么比較直接的做法是這樣的翠忠,0-10M分給A鞠苟,10-110M分給B,如下:


2016-06-04-1
2016-06-04-1

這樣分配秽之,問題會有很多当娱,大致有以下三個:

  1. 地址空間不隔離: 惡意程序可以很容易改寫其他程序的內(nèi)存數(shù)據(jù),如A可以通過類似*(p + 1024 * 1024 * 10) = xxx來訪問到B里的內(nèi)存政溃,這是很危險的趾访。
  2. 內(nèi)存使用率低: 比如我們在A、B同時運行的時候董虱,突然要運行C扼鞋。這個時候內(nèi)存已經(jīng)不夠,我們可以采取的一個辦法是把某個程序的數(shù)據(jù)暫時寫到磁盤里愤诱,等到需要的時候再讀回來云头。這個時候問題來了,由于地址空間是連續(xù)的淫半,我們?nèi)〕鯝也沒法把C放入內(nèi)存運行溃槐,只能取出B,可以看到這是一個巨大的IO操作科吭,會導(dǎo)致效率十分低下昏滴。
  3. 程序運行的地址不確定:因為程序每次需要裝入運行時我們都需要一塊足夠大的空閑區(qū)域猴鲫,這個區(qū)域是不確定的,就需要程序重定位谣殊。

怎么辦拂共?還是那個熟悉的配方,熟悉的味道:增加中間層姻几。

一切計算機(jī)的問題都可以通過增加中間層來解決宜狐。

思想:我們把程序的地址視為一種虛擬地址,然后通過映射的方式將這個虛擬地址轉(zhuǎn)換成實際的物理地址蛇捌。只要我們妥善的處理映射的方式抚恒,就能達(dá)到空間隔離的效果。

分段管理

這個時候分段的管理方法就出現(xiàn)了络拌,先上圖:


2016-06-04-2
2016-06-04-2

分段管理:把一段程序所需要的內(nèi)存大小的虛擬空間映射到某個地址空間俭驮。
零散論點:分段的虛擬空間大小不一定相等,這是一個和分頁不同的特點盒音。
如上圖表鳍,我們A需要10M的大小,那么我們的虛擬空間就是從0x00000000開始到0x00A00000結(jié)束祥诽。所以:

  1. 如果A訪問的地址空間超過了0x00A00000譬圣,那么硬件就會判斷這是個非法訪問,就會拒絕這個請求雄坪,從而實現(xiàn)了隔離厘熟。
  2. 對于程序來說,我們只在0x00000000到0x00A00000來編寫程序维哈、放置變量绳姨,所以程序不需要再重定位。

分段解決了但是分段還是沒有解決我們第二個問題-內(nèi)存使用效率問題阔挠。人們很自然的就想到了更小粒度的內(nèi)存分割和映射方法飘庄,于是,分頁出現(xiàn)了购撼。

分頁管理

分頁的基本方法是把地址空間人為的分成固定大小的頁跪削,一般都是4KB。
首先我們要知道三種頁:

  • 磁盤頁:磁盤中的頁迂求。
  • 虛擬頁:虛擬空間的頁碾盐。
  • 物理頁:物理內(nèi)存中的頁。

程序會放在虛擬頁中揩局,最后進(jìn)行映射毫玖。


2016-06-04-3
2016-06-04-3

我們把程序中常用的數(shù)據(jù)和代碼頁裝到內(nèi)存中(虛擬頁中0、1、7)付枫,把不常用的放在磁盤頁(虛擬頁中2烹玉、3),暫未用到的不映射(虛擬頁中的4励背、5春霍、6)。

頁錯誤

如果進(jìn)程需要使用虛擬頁的2叶眉、3,但是這時它們在磁盤頁中芹枷,硬件會捕獲這個消息衅疙,這就是所謂的頁錯誤

這時操作系統(tǒng)會用自己的辦法(用空再寫鸳慈,就是TLB那塊)把磁盤中表示虛擬頁2饱溢、3的數(shù)據(jù)讀出來并且裝入內(nèi)存。

以頁為單位來存取和交換這些數(shù)據(jù)非常方便走芋,硬件本身就支持這種以頁為單位的操作方式绩郎。

MMU

映射需要硬件來實現(xiàn),幾乎所有的硬件都采用一個叫MMU的部件來進(jìn)行映射翁逞,如圖所示肋杖。


2016-06-04-4
2016-06-04-4

寫在結(jié)尾

如果您有所收獲,希望點個贊支持挖函。
也歡迎收錄我的博客專欄:biggergao的博客状植,謝謝。
Done


作者 @biggergao

2016年06月04日

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末怨喘,一起剝皮案震驚了整個濱河市津畸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌必怜,老刑警劉巖肉拓,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異梳庆,居然都是意外死亡暖途,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進(jìn)店門靠益,熙熙樓的掌柜王于貴愁眉苦臉地迎上來丧肴,“玉大人,你說我怎么就攤上這事胧后∮蟾。” “怎么了?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長纸巷。 經(jīng)常有香客問我镇草,道長,這世上最難降的妖魔是什么瘤旨? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任梯啤,我火速辦了婚禮,結(jié)果婚禮上存哲,老公的妹妹穿的比我還像新娘因宇。我一直安慰自己,他們只是感情好祟偷,可當(dāng)我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布察滑。 她就那樣靜靜地躺著,像睡著了一般修肠。 火紅的嫁衣襯著肌膚如雪贺辰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天嵌施,我揣著相機(jī)與錄音饲化,去河邊找鬼。 笑死吗伤,一個胖子當(dāng)著我的面吹牛吃靠,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播牲芋,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼撩笆,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了缸浦?” 一聲冷哼從身側(cè)響起夕冲,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎裂逐,沒想到半個月后歹鱼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡卜高,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年弥姻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掺涛。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡庭敦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出薪缆,到底是詐尸還是另有隱情秧廉,我是刑警寧澤,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站疼电,受9級特大地震影響嚼锄,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蔽豺,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一区丑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧修陡,春花似錦沧侥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至号杏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間斯棒,已是汗流浹背盾致。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留荣暮,地道東北人庭惜。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像穗酥,于是被迫代替她去往敵國和親护赊。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內(nèi)容