版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 目 錄</b></p><p> 第1章 設(shè)計任務(wù)分析1</p><p> 1.1 虛擬存儲技術(shù)分析1</p><p> 1.1.1 虛擬存儲技術(shù)概述1</p><p> 1.1.2 虛擬存儲技術(shù)的概念1</p><p> 1.1.3 虛擬存
2、儲技術(shù)的優(yōu)勢1</p><p> 1.2 使用算法分析:2</p><p> 1.2.1 FIFO算法(先進(jìn)先出淘汰算法)2</p><p> 1.2.2 LRU算法(最久未使用淘汰算法)3</p><p> 1.2.3 OPT算法(最佳淘汰算法)4</p><p> 第2章 總設(shè)計方案
3、5</p><p> 2.1 置換算法思想5</p><p> 2.1.1 最佳置換算法(Optimal):5</p><p> 2.1.2 先進(jìn)先出(FIFO)頁面置換算法:5</p><p> 2.1.3 LRU置換算法:LRU(Least Recently Used)置換算法的描述5</p&g
4、t;<p> 2.2 LRU置換算法的硬件支持5</p><p> 2.2.1 寄存器5</p><p><b> 2.2.2 棧6</b></p><p> 第3章 程序設(shè)計結(jié)構(gòu)圖7</p><p> 3.1虛擬存儲管理器系統(tǒng)設(shè)計總框圖7</p><p>
5、 3.2各模塊功能N-S圖7</p><p> 第4章 程序測試結(jié)果12</p><p> 第5章 設(shè)計心得14</p><p> 第1章 設(shè)計任務(wù)分析</p><p> 本設(shè)計的目的是通過設(shè)計一個簡單的虛擬存儲器管理系統(tǒng)來模擬實際的頁面調(diào)度算法與過程,以掌握這種有用的技術(shù)。要求將其輸入/輸出處理程序編成一個獨立的進(jìn)程模塊
6、并與其它請求輸入/輸出的進(jìn)程并發(fā)運行。并要求加入設(shè)備管理子模塊。</p><p> 1.1虛擬存儲技術(shù)分析 </p><p> 1.1.1 虛擬存儲技術(shù)概述</p><p> 虛擬存儲技術(shù)是隨著計算機(jī)技術(shù)的發(fā)展而發(fā)展起來的。早在20世紀(jì)70年代,為了克服內(nèi)存容量小成本高而不適應(yīng)大型程序應(yīng)用需要的矛盾,人們開發(fā)了虛擬內(nèi)存技術(shù)。隨著計算機(jī)技術(shù)及相關(guān)信息處理技術(shù)的
7、不斷發(fā)展,人們對存儲的需求越來越大,單個大容量磁盤已不能適應(yīng)應(yīng)用的需要,虛擬存儲技術(shù)又有進(jìn)一步的發(fā)展,如在操作系統(tǒng)下將一組硬盤捆綁成帶區(qū)集(STRIP)作為單個邏輯存儲單元供主機(jī)訪問;磁盤冗余陣列(RAID)技術(shù)將多個物理磁盤通過一定的邏輯關(guān)系集合起來,成為一個大容量的虛擬磁盤。從某種意義上講,SAN本身也是虛擬存儲技術(shù)的應(yīng)用。</p><p> 1.1.2 虛擬存儲技術(shù)的概念</p><
8、;p> 所謂虛擬存儲技術(shù),是指把多個物理上獨立存在的存儲體通過軟件或硬件的手段集中管理起來,形成一個邏輯上的虛擬存儲單元供主機(jī)訪問。這個虛擬邏輯單元的存儲容量是它所集中管理的各物理存儲體的存儲容量之和,而它的訪問帶寬則在一定程度上接近各個物理存儲體的訪問帶寬之和。虛擬存儲實際上是邏輯存儲,是一種智能、有效地管理存儲數(shù)據(jù)的方式。虛擬存儲克服了物理存儲的局限,它可以把物理設(shè)備變成完全不同的邏輯鏡像,呈現(xiàn)給用戶,既充分利用了物理設(shè)備的
9、優(yōu)勢,如高性能、高可用,又打破了物理設(shè)備本身不可克服的局限性。從用戶角度看,使用存儲空間而不是使用物理存儲硬件,管理存儲空間而不是管理物理存儲部件,這就是虛擬存儲的概念。</p><p> 1.1.3 虛擬存儲技術(shù)的優(yōu)勢</p><p> 虛擬存儲技術(shù)不僅可以提高主機(jī)訪問存儲設(shè)備的性能,同時對于存儲容量的擴(kuò)展是非常方便的,可以保護(hù)原有投資,實現(xiàn)不影響正常數(shù)據(jù)訪問的前提下的動態(tài)擴(kuò)容。
10、虛擬存儲技術(shù)為實際應(yīng)用帶來的好處主要體現(xiàn)在以下幾個方面: 1)虛擬存儲技術(shù)使網(wǎng)絡(luò)系統(tǒng)存儲部分的重要指標(biāo)——單個邏輯單元的存儲容量和訪問帶寬相對單個物理存儲體大大提高,適應(yīng)了網(wǎng)絡(luò)應(yīng)用特別是視頻網(wǎng)絡(luò)應(yīng)用的需要。</p><p> 2)在虛擬存儲環(huán)境下,無論后端物理存儲體是什么設(shè)備,服務(wù)器及其應(yīng)用系統(tǒng)看到的都是其熟悉的存儲設(shè)備的邏輯鏡像。即使物理存儲體發(fā)生變化,其邏輯鏡像也不發(fā)生變化,應(yīng)用系統(tǒng)無需關(guān)心后端存儲,
11、只需專注于管理存儲空間,使得存儲管理變得輕松簡單,便于靈活配置。</p><p> 3)虛擬存儲是一種智能化的系統(tǒng),它允許客戶以透明有效的方式在磁盤或磁帶上存儲數(shù)據(jù),使客戶的存儲系統(tǒng)容納更多的數(shù)據(jù),也使更多的用戶可以共享同一個系統(tǒng)。</p><p> 虛擬存儲器的效率是系統(tǒng)性能評價的重要內(nèi)容,它與主存容量、頁面大小、命中率,程序局部性和替換算法等因素有關(guān)。</p>&
12、lt;p> 1.2使用算法分析:</p><p> 1.2.1 FIFO算法(先進(jìn)先出淘汰算法)</p><p> 什么是先進(jìn)先出淘汰算法?</p><p> 該算法總是淘汰最先進(jìn)入內(nèi)存的頁面,即懸著在內(nèi)存中駐留時間最久的頁面予以淘汰。</p><p><b> 實現(xiàn)方法</b></p>
13、<p> 系統(tǒng)保留一張次序表,該表記錄了作業(yè)程序的各頁面進(jìn)入主存的先后次序。</p><p> ·用數(shù)組作次序表可在主存中建立一個m(m是分配給該作業(yè)的存儲塊數(shù))個元素的頁號表和一個調(diào)換指針。如下圖所示:</p><p> ·用存儲分塊表作次序表該次序表以塊號為序,依次各塊的分配情況。這里假定m=4,且4,5,1,2頁以依次裝入2,6,7,4各存儲塊中
14、。此時存儲分塊表如下圖所示:</p><p><b> (a)替換以前</b></p><p> 1.2.2 LRU算法(最久未使用淘汰算法)</p><p> 什么是最久未使用淘汰算法?</p><p> 當(dāng)需要淘汰一頁時,總是選擇最長時間未被使用的那一頁淘汰。</p><p><
15、;b> 實現(xiàn)方法</b></p><p><b> ·用硬件實現(xiàn)</b></p><p> 此算法每一頁可以設(shè)置一個R位的寄存器;</p><p> 每次訪問一頁時,將該頁所對應(yīng)的寄存器的最左一位置1;</p><p> 每隔時間t將所有的R位寄存器右移一位。</p>
16、<p> 這樣,在T=Rt時間內(nèi),方問過的頁多對應(yīng)的寄存器R內(nèi)時一個不全為0的整數(shù),而沒有訪問過的頁相對應(yīng)的R之值為0。當(dāng)缺頁中斷時,選擇R值最小的那頁進(jìn)行淘汰。</p><p><b> ·用頁號棧實現(xiàn)</b></p><p> 此算法設(shè)立一個頁號棧,使棧頂元素為剛北訪問的頁面,而棧底元素為最久未被訪問的頁面。</p><
17、;p> 每當(dāng)訪問頁面時,該頁號棧需進(jìn)行調(diào)整。一個頁面被訪問過,就立即將它的頁號記在頁號棧的頂部,而將棧中原有的頁號依次下移。如果棧中原有的頁號中有與新記入頂部的頁號相重者,則將該重號抽出,且將頁號棧內(nèi)容進(jìn)行緊湊壓縮。</p><p> 1.2.3 OPT算法(最佳淘汰算法)</p><p> 什么是最佳淘汰算法?</p><p> 當(dāng)需要淘汰一頁時,
18、將選擇以后永不使用的或許是在最長(未來)時間內(nèi)不再被訪問的頁面。</p><p><b> 算法優(yōu)勢</b></p><p> 采用最佳置換算法,通??杀WC獲得最低的缺頁率。但由于人目前還無法預(yù)知一個進(jìn)程在內(nèi)存的若干個頁面中,哪一個頁面是未來最長時間內(nèi)不再被訪問的,因而該算法是無法實現(xiàn)的,便可以利用此算法來評價其它算法。</p><p>
19、 第2章 總設(shè)計方案</p><p> 2.1 置換算法思想 </p><p> 2.2.1 最佳置換算法(Optimal): </p><p> 它是由Belady于1966年提出的一種理論上的算法。其所選擇的被淘汰頁面,將是以后永不使用的或許是在最長(未來)時間內(nèi)不再被訪問的頁面。采用最佳置換算法,通??杀WC獲得最低的缺頁率。但由于人目前還
20、無法預(yù)知一個進(jìn)程在內(nèi)存的若干個頁面中,哪一個頁面是未來最長時間內(nèi)不再被訪問的,因而該算法是無法實現(xiàn)的,便可以利用此算法來評價其它算法。 </p><p> 2.1.2 先進(jìn)先出(FIFO)頁面置換算法: </p><p> 這是最早出現(xiàn)的置換算法。該算法總是淘汰最先進(jìn)入內(nèi)存的頁面,即選擇在內(nèi)存中駐留時間最久的頁面予以淘汰。該算法實現(xiàn)簡單只需把一個進(jìn)程已調(diào)入內(nèi)存的頁面,按先后
21、次序鏈接成一個隊列,并設(shè)置一個指針,稱為替換指針,使它總是指向最老的頁面。</p><p> 2.1.3 LRU置換算法:LRU(Least Recently Used)置換算法的描述 </p><p> FIFO置換算法性能之所以較差,是因為它所依據(jù)的條件是各個頁面調(diào)入內(nèi)存的時間,而頁面調(diào)入的先后并不能反映頁面的使用情況。最近最久未使用(LRU)置換算法,是根據(jù)頁面調(diào)入內(nèi)
22、存后的使用情況進(jìn)行決策的。由于無法預(yù)測各頁面將來的使用情況,只能利用“最近的過去”作為“最近的將來”的近似,因此,LRU置換算法是選擇最近最久未使用的頁面予以淘汰。該算法賦予每個頁面一個訪問字段,用來記錄一個頁面自上次被訪問以來所經(jīng)歷的時間t,,當(dāng)須淘汰一個頁面時,選擇現(xiàn)有頁面中其t值最大的,即最近最久未使用的頁面予以淘汰。 </p><p> 2.2 LRU置換算法的硬件支持 </p><
23、;p> LRU置換算法雖然是一種比較好的算法,但要求系統(tǒng)有較多的支持硬件。為了了解一個進(jìn)程在內(nèi)存中的各個頁面各有多少時間未被進(jìn)程訪問,以及如何快速地知道哪一頁是最近最久未使用的頁面,須有以下兩類硬件之一的支持: </p><p> 2.2.1 寄存器 </p><p> 為了記錄某個進(jìn)程在內(nèi)存中各頁的使用情況,須為每個在內(nèi)存中的頁面配置一個移位寄存器,可表示為 </p&g
24、t;<p> R=Rn-1Rn-2Rn-3……R2R1R0 當(dāng)進(jìn)程訪問某物理塊時,要將相應(yīng)寄存器的Rn-1位置成1。此時,定時信號將每隔一定時間(例如100ms)將寄存器右移一位。如果我們把n位寄存器的數(shù)看作是一個整數(shù),那么具有最小數(shù)值的寄存器所對應(yīng)的頁面,就是最近最久未使用的頁面。如圖1示出了某進(jìn)程在內(nèi)存中具有8個頁面,為每個內(nèi)存頁面配置一個8位寄存器時的LRU訪問情況。這里,把8個內(nèi)存頁面的序號分別定為1??8。由圖
25、可以看出,第7個內(nèi)存頁面的R值最小,當(dāng)發(fā)生缺頁時首先將它置換出去。 </p><p><b> 2.2.2 棧 </b></p><p> 可利用一個特殊的棧來保存當(dāng)前使用的各個頁面的頁面號。每當(dāng)進(jìn)程訪問某頁面時,便將頁面的頁面號從棧中移出,將它壓入棧頂。因此,棧頂始終是最新被訪問頁面的編號民,而棧底則是最近最久未使用的頁面的頁面號。 </p&g
26、t;<p> 第3章 程序設(shè)計結(jié)構(gòu)圖</p><p> 3.1虛擬存儲管理器系統(tǒng)設(shè)計總框圖</p><p> 系統(tǒng)功能描述:通過設(shè)計操作系統(tǒng)中虛擬存儲管理系統(tǒng)解決存儲容量和存取速度矛盾,是管理存儲設(shè)備的有效方法。使用FIFO,LRU,OPT,三種置換算法置換頁面進(jìn)行比較,選擇適合虛擬存儲管理系統(tǒng)理想的調(diào)度算法。</p><p> 3.2各模塊功
27、能N-S圖</p><p> 尋找時間最長的頁面功能模塊:</p><p> 算法思想:通過尋找時間最長的頁面,為進(jìn)行FIFO,LRU,ORT三種調(diào)度算法運算提供前提條件。</p><p> 主要參數(shù)功能 :Pro *page 用來指向調(diào)入內(nèi)存最長時間的頁面</p><p> Max()函數(shù)N-S圖</p><p&
28、gt; 內(nèi)存頁面輸入功能模塊:</p><p> 算法思想:通過輸入內(nèi)存頁面,選擇調(diào)度功能,并輸入正確頁面流文件名,顯示讀入的頁面流,如文件不符,則顯示“錯誤,文件打不開,請檢查文件名”。</p><p> 指針頁面移動功能模塊:</p><p> 算法思想:通過指針移動進(jìn)行頁面置換的工作。</p><p><b> FI
29、FO功能模塊:</b></p><p> 算法思想:該算法總是淘汰最先進(jìn)入內(nèi)存的頁面,即選擇在內(nèi)存中駐留時間最久的頁面予以淘汰。該算法實現(xiàn)簡單只需把一個進(jìn)程已調(diào)入內(nèi)存的頁面,按先后次序鏈接成一個隊列,并設(shè)置一個指針,稱為替換指針,使它總是指向最老的頁面。</p><p><b> LRU功能模塊:</b></p><p> 算
30、法思想:最近最久未使用(LRU)置換算法,是根據(jù)頁面調(diào)入內(nèi)存后的使用情況進(jìn)行決策的。由于無法預(yù)測各頁面將來的使用情況,只能利用“最近的過去”作為“最近的將來”的近似,因此,LRU置換算法是選擇最近最久未使用的頁面予以淘汰。該算法賦予每個頁面一個訪問字段,用來記錄一個頁面自上次被訪問以來所經(jīng)歷的時間t,,當(dāng)須淘汰一個頁面時,選擇現(xiàn)有頁面中其t值最大的,即最近最久未使用的頁面予以淘汰。 </p><p><b&
31、gt; OPT算法思想:</b></p><p> 選擇的被淘汰頁面,將是以后永不使用的或許是在最長(未來)時間內(nèi)不再被訪問的頁面。采用最佳置換算法,通常可保證獲得最低的缺頁率。但由于人目前還無法預(yù)知一個進(jìn)程在內(nèi)存的若干個頁面中,哪一個頁面是未來最長時間內(nèi)不再被訪問的,因而該算法是無法實現(xiàn)的,便可以利用此算法來評價其它算法。 </p><p> 第4章 程序測試結(jié)果&l
32、t;/p><p><b> 第5章 設(shè)計心得</b></p><p> 通過近一個月的課程設(shè)計,加深了對操作系統(tǒng)的認(rèn)識,了解了操作系統(tǒng)中各種資源分配算法的實現(xiàn),特別是對虛擬存儲,頁面置換有了深入的了解,并能夠用高級語言進(jìn)行模擬演示。這次的操作系統(tǒng)大作業(yè)的工作量比較大,我投入了很多的時間和精力才完成了系統(tǒng)的設(shè)計。不過這些付出都是值得的,因為我收獲了更多。</p&
33、gt;<p> 首先,我必須要了解虛擬內(nèi)存的特性,通過到圖書館找資料,翻閱書本和網(wǎng)上搜索,理解到虛擬頁式管理的基本原理是系統(tǒng)自動地將作業(yè)的地址空間分頁,將系統(tǒng)的主存空間分塊,頁與塊等大小,在作業(yè)運行前,只把初始需要的一部分頁面裝入內(nèi)存塊里,運行中需要訪問自己地址空間中的當(dāng)前不在內(nèi)存的頁面時產(chǎn)生缺頁中斷,由缺頁中斷服務(wù)程序?qū)⑺璧捻撁嬲{(diào)入內(nèi)存,若此時內(nèi)存中沒有空閑物理塊安置請求調(diào)入的新頁面,則系統(tǒng)按預(yù)定的置換策略自動選擇一
34、個或一些在內(nèi)存的頁面,把它們換出到外存。還有研究了主存頁面的分配策略和頁面調(diào)入時機(jī)。這對之后的算法編寫有很大的幫助。</p><p> 其后,是要熟悉各算法的思想,我重新復(fù)習(xí)了操作系統(tǒng)頁面調(diào)度中OPT、FIFO、LRU的算法,上網(wǎng)查閱各算法的資料,經(jīng)過一段時間的研究,我開始編寫算法的程序。雖然了解了各算法的思想,但到編寫起程序來,還是有一點難度,又需要再復(fù)習(xí)C++的部分語法,如文件流的輸入輸出,因為對課堂知識只
35、是了解,但實踐中有些不常用的命令很容易會遺忘。開始時還是毫無頭緒,參考到一些資料和網(wǎng)上有關(guān)的代碼,經(jīng)過跟組員研究后,試著寫一段測試一段地,逐漸把程序完善。在此過程中,兩種頁面置換算法FIFO和LRU理解起來相當(dāng)容易,但在實際編程實現(xiàn)的時候需要注意各種細(xì)節(jié),需要耐心細(xì)致,實際編程中遇到一些細(xì)節(jié)上的小問題確實需要仔細(xì)考慮才行。另外,先進(jìn)先出頁面置換和LRU算法兩者各有特點,但是實踐起來卻很大,使自己對頁面置換算法有了新的認(rèn)識。在我做預(yù)設(shè)計的
36、時候因為還沒有完善好程序的功能,所以這方面我的工作做得不夠完美,不夠具體,在詳細(xì)設(shè)計和編程中,我們都修復(fù)了這些缺點并進(jìn)行了改善,像界面變得更美化些,程序上變得更簡潔些容易修改些。</p><p> 然后是設(shè)計功能及界面,參考了許多相關(guān)的程序代碼和書本的資料,以及按照指導(dǎo)書的要求,我初步設(shè)計了個輪廓,功能方面也只能按理想化設(shè)計,因為未有實際操作到,還不能預(yù)計到一些實際性的問題。</p><p&
37、gt; 在本次實驗中,通過瀏覽、閱讀有關(guān)的資料,學(xué)到了很多東西,同時也發(fā)現(xiàn)僅僅書本的知識是遠(yuǎn)遠(yuǎn)不夠的,需要把知識運用到實踐中去,能力才能得到提高。通過分工合作,發(fā)揮了同學(xué)互相幫助,團(tuán)結(jié)合作精神,遇到不會的問題一起討論,查資料,問老師,在老師的指導(dǎo)和同學(xué)的幫助下,我收益良多。</p><p><b> 參考文獻(xiàn)</b></p><p> [1] 計算機(jī)操
38、作系統(tǒng)基礎(chǔ) 湯曉丹 、梁紅兵 西安電子工業(yè)出版社</p><p> [2] Linux 操作系統(tǒng)內(nèi)核分析 陳莉君 北京人民郵電出版社</p><p> [3] 網(wǎng)絡(luò)操作系統(tǒng) 徐甲同 吉林大學(xué)出版社</p><p>
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(tǒng)課程設(shè)計存儲管理
- 課程設(shè)計---存儲器管理系統(tǒng)設(shè)計
- 虛擬存儲器課程設(shè)計
- 操作系統(tǒng)存儲器管理——最佳適應(yīng)算法
- 操作系統(tǒng)課程設(shè)計——操作系統(tǒng)課程設(shè)計模擬操作系統(tǒng)
- 內(nèi)存管理(操作系統(tǒng))操作系統(tǒng)課程設(shè)計
- 模擬頁式存儲管理-操作系統(tǒng)課程設(shè)計
- 模擬頁式存儲管理 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計--請求頁式存儲管理
- 操作系統(tǒng)課程設(shè)計--請求頁式存儲管理
- 操作系統(tǒng)課程設(shè)計--- 請求調(diào)頁存儲管理
- 操作系統(tǒng)課程設(shè)計--請求頁式存儲管理
- 操作系統(tǒng)課程設(shè)計---文件加密存儲
- 操作系統(tǒng)課程設(shè)計-- 操作系統(tǒng)
- 支持Linux操作系統(tǒng)的存儲器管理單元設(shè)計研究.pdf
- 操作系統(tǒng)課程設(shè)計---動態(tài)分區(qū)分配存儲管理
- 操作系統(tǒng)課程設(shè)計--模擬實現(xiàn)可變分區(qū)存儲管理
- 操作系統(tǒng)原理課程設(shè)計報告-可變分區(qū)存儲管理
- 模擬頁式存儲管理-操作系統(tǒng)課程設(shè)計報告
- 操作系統(tǒng)課程設(shè)計---進(jìn)程管理系統(tǒng)
評論
0/150
提交評論