模擬設計頁式存儲管理的分配與回收_第1頁
模擬設計頁式存儲管理的分配與回收_第2頁
模擬設計頁式存儲管理的分配與回收_第3頁
模擬設計頁式存儲管理的分配與回收_第4頁
模擬設計頁式存儲管理的分配與回收_第5頁
已閱讀5頁,還剩13頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、題 目: 模擬設計頁式存儲管理的分配與回收1需求分析頁式管理是一種內存空間存儲管理的技術,頁式管理分為靜態頁式管理和動態頁式管理。基本原理是將各進程的虛擬空間劃分成若干個長度相等的頁(page),頁式管理把內存空間按頁的大小劃分成片或者頁面(page frame),然后把頁式虛擬地址與內存地址建立一一對應頁表,并用相應的硬件地址變換機構,來解決離散地址變換問題。頁式管理采用請求調頁或預調頁技術實現了內外存存儲器的統一管理。 圖1 頁的劃分圖2 基本頁表示例靜態分頁管理的第一步是為要求內存的作業或進程分配足夠的頁面。系統通過存儲頁面表、請求表以及頁表來完成內存的分配工作。頁表指的是內存中的一塊固

2、定存儲區。頁式管理時每個進程至少有一個頁表。請求表指的是用來確定作業或進程的虛擬空間的各頁在內存中的實際對應位置;另外整個系統有一個存儲頁面表,其描述了物理內存空間的分配使用狀況。圖3 請求表的示例存儲頁面表有兩種構成方法:1、位示圖法2、空閑頁面鏈表法模擬設計頁式存儲管理的分配與回收要求能夠滿足如下的要求:(1) 輸入給定的內存頁面數,頁面大小,進程的個數及每個進程的頁數。(2) 要求當某進程提出申請空間的大小后,顯示能否滿足申請,以及為該進程分配資源后內存空間的使用情況(被進程占用的頁面,空閑的頁面)。2 功能設計2.1 算法分析首先,請求表給出進程或作業要求的頁面數。然后,由存儲頁面表檢

3、查是否有足夠的空閑頁面,如果沒有,則本次無法分配。如果有則首先分配設置頁表,并請求表中的相應表項后,按一定的查找算法搜索出所要求的空閑頁面,并將對應的頁好填入頁表中。 圖4 分配頁面的算法流程2.2 數據結構頁式管理把內存空間按頁的大小劃分成片或者頁面,再按照一定的規律建立起頁表,并通過請求表將分配內容顯示出來.將頁表和請求表的內容使用結構體來定義是比較方便的. /頁表項結構 typedef struct _pagetableitempageid pagenum;/頁號blockid blocknum;/塊號pgtabitem;/頁表typedef pgtabitem * pagetable;

4、/請求表結構typedef struct _reqtableunsigned pid;/進程號unsigned reqpagenum;/請求頁面數pagetable pgtabadr; /頁表始址bool state;/狀態 reqtabitem;請求表還引入了支持快速插入和刪除的list順序容器來進行相關操作.list<reqtabitem> reqtable因為模擬設計的關系,頁面的起始地址均應該為隨機的數值,所以程序在設計過程中加入了隨機數類的編寫.class RandomNumberprivate: unsigned long randseed;public: Random

5、Number(unsigned long s=0); unsigned short Random(unsigned long n); double fRandom(void);采用當前系統的時間值來生成偽隨機數分配地址.定義隨機數產生器:RandomNumber random 定義內存頁面數:int pagenum 定義頁面大小:int pagesize定義進程個數:int pnum用整數數組模擬分配的內存頁面數int * mempage=new intpagenum2.3模塊說明2.3.1 主函數主函數依次運行了程序中所實現的關鍵函數. int main() InitSys(); /初始化系

6、統 MainChoice();/輸出系統菜單 Destroy(); /釋放申請的動態內存 return 0;2.3.2 各個功能函數 初始化內存頁面: void Init_Mempage(void)獲取內存使用情況: int Get_Mempagenum(void)初始化默認的請求表: void Init_Reqtable(void)為默認的進程分配內存: void Init_DistMem(void)手動創建進程,并分配內存: void Dist_Mem(void)釋放申請的動態內存: void Destroy(void)結束指定進程: void Kill(void) 2.3.3 打印函數

7、打印出進程請求表: void PrintReqtable(void) 打印出頁表: void PrintPageTable(void) 打印出內存使用情況: void PrintMem(void) 打印出物理塊的大小: void PrintBlockSize(void)2.3.4 其他函數 初始化系統: void InitSys(void)輸出主菜單: void MainMenu(void) 選擇運行分支:void MainChoice() 3開發平臺3.1開發平臺(1) 使用系統:Windows 7(2) 使用語言:C+(3) 開發工具:Visual C+ 20084測試用例,運行結果與運行

8、情況分析4.1測試方法 通過輸入正常數據以及非正常數據對程序進行全方位測試4.2測試結果(1)程序主界面(2)輸入進程號和頁面數:(3)顯示進程頁表:(4)顯示請求表(5)顯示內存使用情況以及物理塊大小(6)錯誤檢驗5源程序的主要部分#include <iostream>#include <cstdlib>#include <iomanip>#include <list>#include "page.h"#include "Random.h"using namespace std;list<reqta

9、bitem> reqtable;RandomNumber random; /隨機數產生器unsigned pagenum=random.Random(80)+21; /內存頁面數21-100unsigned pagesize=random.Random(16)+5; /頁面大小5-20 unsigned pnum=random.Random(4)+5;/進程的個數5-8int * mempage=new intpagenum; /用整數數組模擬內存頁面數/*初始化內存頁面*/void Init_Mempage(void)int i=0;for(i=0;i<int(pagenum);

10、i+)mempagei=0; /數組全部賦初值/*獲取內存的使用情況*/int Get_Mempagenum(void)int sum=0;for(int i=0;i<int(pagenum);i+)if(mempagei=0)sum+;return sum; /判斷有多少內存頁面已經被使用/*初始化默認的請求表*/void Init_Reqtable(void)int i;for(i=1;i<=int(pnum);i+)reqtabitem preq;preq.pid=i;preq.reqpagenum=random.Random(4)+2;/進程請求的頁面大小-5preq.st

11、ate=false;preq.pgtabadr=NULL;reqtable.push_back(preq); /依次壓入容器 /*為默認的進程分配內存*/void Init_DistMem(void)int reqpnum;/進程請求頁面數int i;list<reqtabitem>:iterator pos=reqtable.begin();for(;pos!=reqtable.end();pos+)reqpnum=(*pos).reqpagenum;if(reqpnum>int(Get_Mempagenum()/判斷請求的內存頁面數目是否大于剩余的cout<<

12、"沒有足夠的內存!"<<endl; cout<<endl; else(*pos).state=true;pagetable temp = new pgtabitemreqpnum; /新建臨時頁表項數組if(temp=NULL)cout<<"內存分配失敗!"<<endl;exit(0);(*pos).pgtabadr=temp;for(i=0;i<reqpnum;i+)tempi.pagenum=i;/頁表的頁號int randnum=random.Random(pagenum)+1;/隨機產生一個塊

13、號while(mempagerandnum=1)randnum=random.Random(pagenum)+1;tempi.blocknum=randnum;/頁表的塊號mempagerandnum=1;/*手動創建進程,并分配內存*/void Dist_Mem(void)int i;reqtabitem preq;/新創建進程記錄int pid;/進程號int reqpnum;/請求頁面數bool flag=false;docout<<"請輸入進程號:"flag=false;cin>>pid;for(list<reqtabitem>:

14、iterator pos=reqtable.begin();pos!=reqtable.end();pos+)if(*pos).pid=pid)flag=true;cout<<"該進程號已經存在,請重新輸入"<<endl;cout<<endl;break;while(flag=true); /循環直到輸入的Pid滿足條件preq.pid=pid;cout<<"請輸入需要的頁面數:"cin>>reqpnum;preq.reqpagenum=reqpnum;preq.state=false;preq

15、.pgtabadr=NULL;reqpnum=preq.reqpagenum;if(reqpnum>Get_Mempagenum()cout<<"沒有足夠的內存,進程創建失敗!"<<endl; cout<<endl;elsepreq.state=true;pagetable temp = new pgtabitemreqpnum;if(temp=NULL)cout<<"內存分配失敗!"<<endl;exit(0);preq.pgtabadr=temp;for(i=0;i<int(re

16、qpnum);i+)tempi.pagenum=i;/頁表的頁號int randnum=random.Random(pagenum)+1;/隨機產生一個塊號while(mempagerandnum=1)randnum=random.Random(pagenum)+1;tempi.blocknum=randnum;/頁表的塊號mempagerandnum=1;reqtable.push_back(preq);/將該進程的記錄加入請求表/*程序結束時,釋放申請的動態內存*/void Destroy(void)list<reqtabitem>:iterator pos=reqtable.

17、begin();for(pos=reqtable.begin();pos!=reqtable.end();pos+)if(*pos).state=true)delete (*pos).pgtabadr;reqtable.clear();/* 打印出進程請求表*/void PrintReqtable(void) cout<<endl; cout<<"|-|"<<endl; cout<<"| 進程請求表 |"<<endl; cout<<"|-|"<<end

18、l; cout<<"|"<<setw(8)<<"進程號" <<setw(16)<<"請求頁面數" <<setw(16)<<"頁表起始地址" <<setw(16)<<"頁表長度" <<setw(16)<<"狀態 |"<<endl; cout<<"|-|"<<endl; list<reqt

19、abitem>:iterator pos=reqtable.begin(); for(pos=reqtable.begin();pos!=reqtable.end();pos+) cout<<"|"<<setw(8)<<(*pos).pid<<setw(16)<<(*pos).reqpagenum<<setw(16)<<(*pos).pgtabadr<<setw(16)<<(*pos).reqpagenum) * pagesize;if(*pos).state)

20、cout<<setw(4)<<"已分配 |"<<endl;else cout<<setw(4)<<"未分配 |"<<endl;if(*pos).pid!=reqtable.back().pid)cout<<"|-|"<<endl;elsecout<<"|-|"<<endl; /*打印頁表*/void PrintPageTable(void) unsigned pid; int i; bool fl

21、ag=false; cout<<"請輸入進程號:" cin>>pid; list<reqtabitem>:iterator pos=reqtable.begin(); for(pos=reqtable.begin();pos!=reqtable.end();pos+) if(*pos).pid=pid&&(*pos).state=true) flag=true;cout<<"|-|"<<endl;cout<<"| 此進程的頁表 |"<<

22、endl;cout<<"|-|"<<endl;cout<<"|"<<setw(16)<<"頁號"<<setw(6)<<"塊號 |"<<endl;cout<<"|-|"<<endl;int reqpagenum=(*pos).reqpagenum;for(i=0;i<reqpagenum;i+)cout<<"|"<<setw(16

23、)<<(*pos).pgtabadri.pagenum<<setw(6)<<(*pos).pgtabadri.blocknum<<" |"<<endl;if(i!=reqpagenum-1)cout<<"|-|"<<endl;elsecout<<"|-|"<<endl; if(flag=false) cout<<"系統中不存在該進程或者該進程還沒有被分配內存!n" cout<<endl

24、;void PrintMem(void)cout<<"內存總塊數為"<<pagenum<<",已經使用了"<<pagenum-Get_Mempagenum()<<"塊!"<<endl;cout<<"現在還有"<<Get_Mempagenum()<<"塊內存區域空閑!"<<endl;cout<<endl;void PrintBlockSize(void)cout<

25、;<"物理塊大小為:"<<pagesize<<"KB"<<endl;cout<<endl;/*結束指定進程*/void Kill(void)bool flag;int i;reqtabitem temp;list<reqtabitem>:iterator pos=reqtable.begin();int pid;docout<<"請輸入進程號:"flag=false;cin>>pid;for(pos=reqtable.begin();pos!=r

26、eqtable.end();pos+)if(*pos).pid=pid)flag=true;temp=*pos;break;if(flag=false)cout<<"系統中不存在該進程!"<<endl; cout<<endl;while(flag=false);for(i=0;i<int(temp.reqpagenum);i+)mempagetemp.pgtabadri.blocknum=0;reqtable.remove(temp);/重新為沒有分配到內存的進程分配內存for(pos=reqtable.begin();pos!=r

27、eqtable.end();pos+)if(*pos).state=false)int reqpnum;reqpnum=(*pos).reqpagenum;if(reqpnum<=Get_Mempagenum()(*pos).state=true;pagetable temp = new pgtabitemreqpnum;if(temp=NULL)cout<<"內存分配失敗!"<<endl;cout<<endl;exit(0);(*pos).pgtabadr=temp;for(i=0;i<int(reqpnum);i+)tem

28、pi.pagenum=i;/頁表的頁號int randnum=random.Random(pagenum)+1;/隨機產生一個塊號while(mempagerandnum=1)randnum=random.Random(pagenum)+1;tempi.blocknum=randnum;/頁表的塊號mempagerandnum=1;/*初始化系統*/void InitSys(void)cout.setf(ios:left);/左對齊Init_Mempage();Init_Reqtable();Init_DistMem();/*輸出主菜單*/void MainMenu(void) cout<

29、;<"頁式存儲管理的分配與回收"<<endl; cout<<"1.手動創建進程"<<endl; cout<<"2.顯示進程頁表"<<endl; cout<<"3.顯示請求表"<<endl; cout<<"4.撤銷進程"<<endl; cout<<"5.顯示內存使用情況"<<endl; cout<<"6.顯示物理塊大小"<<endl; cout<<"7.退出系統"<<endl; cout<<"請輸入您的選擇(0-7):"/*選擇函數*/void MainChoice()int choice;do MainMenu(); cin>>choice; swi

溫馨提示

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

評論

0/150

提交評論