ch4-4.2連續(xù)存儲空間管理_第1頁
已閱讀1頁,還剩25頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、第四章 存儲管理,4.2 連續(xù)存儲空間管理,4.2.1 固定分區(qū)存儲管理 4.2.2 可變分區(qū)存儲管理 4.2.3 伙伴系統(tǒng)4.2.4 主存不足的存儲管理技術(shù),4.2.1 固定分區(qū)存儲管理,固定分區(qū)存儲管理是實現(xiàn)多道程序設(shè)計的最簡單的一種存儲管理技術(shù)。基本思想:在作業(yè)未進(jìn)入內(nèi)存之前,就由操作員或操作系統(tǒng)把內(nèi)存可用空間劃分成若干個固定大小的存儲區(qū),除操作系統(tǒng)占用一個區(qū)域外,其余區(qū)域為系統(tǒng)中多個用戶共享。在系統(tǒng)運行期間,分區(qū)大小

2、、數(shù)目都不變,所以固定式分區(qū)也稱為靜態(tài)分區(qū)。,,為了便于管理整個內(nèi)存,建立一個表格“主存分配表”來登記和管理整個內(nèi)存。在這個表中登記了每一個分區(qū)的大小,起始地址和分配狀態(tài)。當(dāng)有作業(yè)裝入時,系統(tǒng)便可以搜索這個表,找出一個大小合適的分區(qū)分配給它。當(dāng)程序運行結(jié)束時,可以把它所占用的空間再釋放回去。,4.2.1 固定分區(qū)存儲管理,大小相等的分區(qū),使用哪個分區(qū)都一樣對大小不等的分區(qū),有兩種方法:多個輸入隊列:將每個進(jìn)程指定到適應(yīng)它的最小分區(qū)

3、;每個分區(qū)都需要一個調(diào)度隊列,用于保存為這個分區(qū)換出的進(jìn)程。一個輸入隊列: 為所有進(jìn)程提供一個隊列,當(dāng)需要把一個進(jìn)程裝入主存時,選擇可以保存該進(jìn)程的可用分區(qū)。如果所有分區(qū)都被占用,需要等待。,,4.2.1 固定分區(qū)存儲管理,優(yōu)點可以支持多道程序;實現(xiàn)簡單,開銷小。缺點作業(yè)必須預(yù)先能夠估計自己要占用多大的內(nèi)存空間,有時候這是難以做到的;存在內(nèi)碎片;分區(qū)總數(shù)固定,限制了并發(fā)執(zhí)行的程序個數(shù)。,4.2.1 固定分區(qū)存儲管理,4.2.2

4、可變分區(qū)存儲管理,基本思想: 內(nèi)存不是預(yù)先劃分好的,而是當(dāng)作業(yè)裝入時,根據(jù)作業(yè)的需求和內(nèi)存空間的使用情況來決定是否分配。若有足夠的空間,則按需要分割一部分分區(qū)給該進(jìn)程否則令其等待主存空間,,可變分區(qū)主存分配表可由兩張表格組成:“已分配區(qū)表”和“未分配區(qū)表”分區(qū)分配:尋找某個空閑分區(qū),其大小需大于或等于程序的要求。若是大于要求,則將該分區(qū)分割成兩個分區(qū)。分區(qū)的先后次序通常是從內(nèi)存低端到高端。分區(qū)釋放:需要將相鄰的空閑分區(qū)合并成一個

5、空閑分區(qū),登記到“未分配區(qū)表”中。(可分為4中情況),4.2.2 可變分區(qū)存儲管理,可變分區(qū)管理分配算法,1)最先適應(yīng)分配算法 2)下次適應(yīng)分配算法3) 最優(yōu)適應(yīng)分配算法 4)最壞適應(yīng)分配算法5) 快速適應(yīng)分配算法,為了將一個進(jìn)程裝入內(nèi)存,應(yīng)按照一定的分配算法從空閑分區(qū)表(鏈)中選 出一個滿足進(jìn)程需求的分區(qū)分配給作業(yè)。目前常用分配算法有:,最先適應(yīng)分配算法,算法:空閑分區(qū)(鏈)按地址遞增的次序排列。在進(jìn)行內(nèi)存分配時,從空

6、閑分區(qū)表/鏈?zhǔn)组_始順序查找,直到找到第一個滿足其大小要求的空閑分區(qū)為止。然后再按照進(jìn)程大小,從該分區(qū)中劃出一塊內(nèi)存空間分配給請求者,余下的空閑分區(qū)仍留在空閑分區(qū)表(鏈)中。,下次適應(yīng)分配算法,算法要求 又稱為循環(huán)首次適應(yīng)算法,由首次適應(yīng)算法演變而來。在為進(jìn)程分配內(nèi)存空間時,不再每次從空閑分區(qū)表/鏈?zhǔn)组_始查找,而是從上次找到的空閑分區(qū)的下一個空閑分區(qū)開始查找,直到找到第一個能滿足其大小要求的空閑分區(qū)為止。然后,再按照

7、進(jìn)程大小,從該分區(qū)中劃出一塊內(nèi)存空間分配給請求者,余下的空閑分區(qū)仍留在空閑分區(qū)表/鏈中。,最優(yōu)適應(yīng)分配算法,算法要求: 空閑分區(qū)表/鏈按容量大小遞增的次序排列。在進(jìn)行內(nèi)存分配時,從空閑分區(qū)表/鏈的首開始順序查找,直到找到第一個滿足其大小要求的空閑分區(qū)為止。 按這種方式為進(jìn)程分配內(nèi)存,就能把既滿足進(jìn)程要求又與進(jìn)程大小最接近的空閑分區(qū)分配給進(jìn)程。如果該空閑分區(qū)大于進(jìn)程的大小,則與首次適應(yīng)算法相同,

8、將剩余空閑分區(qū)仍留在空閑分區(qū)表/鏈中。較大的空閑分區(qū)可以被保留。,最壞適應(yīng)分配算法,算法要求:空閑分區(qū)表/鏈按容量大小遞減的次序排列。在進(jìn)行內(nèi)存分配時,取最前面所有空閑區(qū)中最大的一塊,把剩余的塊再變成一個新的小一點的空閑區(qū)?;静涣粝滦】臻e分區(qū),但較大的空閑分區(qū)不被保留。,,地址轉(zhuǎn)換固定分區(qū)存儲管理采用靜態(tài)地址重定位可變分區(qū)存儲管理采用動態(tài)地址重定位存儲保護(hù)存儲保護(hù)是為了防止一個作業(yè)有意或無意地破壞操作系統(tǒng)或其它進(jìn)程。常用的

9、存儲保護(hù)方法有:界限寄存器方法存儲保護(hù)鍵方法,地址轉(zhuǎn)換與存儲保護(hù),1、界限寄存器方法 上下界寄存器方法:用這兩個寄存器分別存放進(jìn)程的起始地址和結(jié)束地址。在進(jìn)程運行過程中,將每一個訪問內(nèi)存的地址都同這兩個寄存器的內(nèi)容比較,如超出這個范圍便產(chǎn)生保護(hù)性中斷?;?、限長寄存器方法:用這兩個寄存器分別存放作業(yè)的起始地址和作業(yè)的地址空間長度。當(dāng)作業(yè)執(zhí)行時,將每一訪問內(nèi)存的相對地址和限長寄存器比較,如果超過了限長寄存器的值,則發(fā)出越界中斷信號

10、,并停止作業(yè)的運行。,地址轉(zhuǎn)換與存儲保護(hù),2、存儲保護(hù)鍵方法 給每個存儲塊(大小相同,一個分區(qū)為整數(shù)倍存儲塊)分配一個單獨的保護(hù)鍵,它相當(dāng)于一把鎖。進(jìn)入系統(tǒng)的每個進(jìn)程也賦予一個保護(hù)鍵,它相當(dāng)于一把鑰匙。當(dāng)進(jìn)程運行時,檢查鑰匙和鎖是否匹配,如果不匹配,則系統(tǒng)發(fā)出保護(hù)性中斷信號,停止進(jìn)程運行。,地址轉(zhuǎn)換與存儲保護(hù),4.2.4 主存不足的存儲管理技術(shù),,1移動技術(shù),內(nèi)碎片:在固定分區(qū)方式中,一個分區(qū)分配給作業(yè)后,分區(qū)中未

11、使用的空間區(qū)稱為內(nèi)碎片,又稱內(nèi)零頭。外碎片:主存中的一個空閑區(qū)域在分配給作業(yè)后,一般總是剩余一個更小的空閑區(qū)。當(dāng)這樣的小分區(qū)不能再裝入一個作業(yè)時,即不能被利用時,它們也成為主存碎片,這樣的分區(qū)在作用使用的分區(qū)之外,所以稱為外碎片??捎靡苿蛹夹g(shù)來解決碎片問題。,4.2.4 主存不足的存儲管理技術(shù),,將內(nèi)存中所有作業(yè)移到內(nèi)存一端,使本來分散的多個小空閑分區(qū)連成一個大的空閑區(qū)。,有關(guān)移動問題討論,移動條件空閑區(qū)的總和滿足分配要求移動時

12、機(jī)分區(qū)回收時當(dāng)找不到足夠大的空閑分區(qū)且總空閑分區(qū)容量可以滿足作業(yè)要求時移動算法作業(yè)在內(nèi)存中的位置發(fā)生了變化,這就必須對其地址加以修改或變換即稱為重定位,2 對換技術(shù),對換技術(shù)也是“擴(kuò)充”內(nèi)存容量和提高內(nèi)存利用率的有效措施。現(xiàn)代OS中廣泛采用。 最早用在MIT的兼容分時系統(tǒng)CTSS中,任何時刻系統(tǒng)中只有一個完整的用戶作業(yè),當(dāng)運行一段時間后,因時間片用完或等待某事件發(fā)生,系統(tǒng)就把它交換到外存上,同時把另一作業(yè)調(diào)入內(nèi)存讓其運行,這樣

13、,可以在內(nèi)存容量不大的小型機(jī)上分時運行,早期的一些分時系統(tǒng)多數(shù)采用這種交換技術(shù)。,交換技術(shù):將暫時不用的某個進(jìn)程及數(shù)據(jù)(首先是處于阻塞狀態(tài)優(yōu)先級最低的)部分(或全部)從內(nèi)存移到到外存(備份區(qū)或?qū)Q區(qū),采用連續(xù)分配的動態(tài)存儲管理方式)中去,讓出內(nèi)存空間,同時將某個需要的進(jìn)程調(diào)入到內(nèi)存中,讓其運行。交換到外存的進(jìn)程需要時可以被再次交換回(選擇換出時間最久的)內(nèi)存中繼續(xù)執(zhí)行。這種內(nèi)存擴(kuò)充技術(shù)就是對換技術(shù)。,2 對換技術(shù),3 覆蓋技術(shù),覆蓋技術(shù)

14、主要用在早期的OS中(內(nèi)存<64KB),可用的存儲空間受限,某些大作業(yè)不能一次全部裝入內(nèi)存,產(chǎn)生了大作業(yè)與小內(nèi)存的矛盾。 例:,,覆蓋:把一個程序劃分為一系列功能相對獨立的程序段(稱為覆蓋),讓執(zhí)行時并不要求同時裝入內(nèi)存的覆蓋組成一組(稱為覆蓋段),共享主存的同一個區(qū)域,從而解決在小的存儲空間中運行大作業(yè)問題。這種內(nèi)存擴(kuò)充技術(shù)就是覆蓋。,3 覆蓋技術(shù),對換與覆蓋技術(shù)的對比,覆蓋與對換技術(shù)是在多道程序環(huán)境下用來擴(kuò)充內(nèi)存的兩種方法

15、。覆蓋技術(shù)主要用在早期的OS中,而對換技術(shù)則主要用在現(xiàn)代OS中,解決在小的內(nèi)存空間運行大作業(yè)的問題,是“擴(kuò)充”內(nèi)存容量和提高內(nèi)存利用率的有效措施。對換技術(shù)不要求程序員給出程序段之間的覆蓋結(jié)構(gòu),對換主要在作業(yè)或進(jìn)程之間進(jìn)行。,覆蓋技術(shù)要求程序員必須把一個程序劃分成不同的程序段,并規(guī)定好它們的執(zhí)行和覆蓋順序,操作系統(tǒng)根據(jù)程序員提供的覆蓋結(jié)構(gòu)來完成程序段之間的覆蓋。覆蓋技術(shù)主要在同一個作業(yè)或進(jìn)程中進(jìn)行,同時覆蓋只能覆蓋與覆蓋程序段無關(guān)的程

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論