您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 公司方案 > 计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告
计算机操作系统实验报告实验二实验题目:存储器管理系别:计算机科学与技术系班级:姓名:学号:2一、实验目的深入理解动态分区存储管理方式下的内存空间的分配与回收。二、实验内容编写程序完成动态分区存储管理方式下的内存分配和回收的实现。具体内容包括:确定用来管理内存当前使用情况的数据结构;采用首次适应算法完成内存空间的分配;分情况对作业进行回收;编写主函数对所做工作进行测试。三、实验原理分配:动态分区存储管理方式把内存除OS占用区域外的空间看作一个大的空闲区。当作业要求装入内存时,根据作业需要内存空间的大小查询内存中各个空闲区,当从内存中找到一个大于或等于该作业大小的内存空闲区时,选择其中一个空闲区,按作业要求划出一个分区装入该作业。回收:作业执行完后,它所占用的内存空间被收回,成为一个空闲区。如果该空闲区的相邻分区也是空闲区,则需要将相邻空闲区合并成一个空闲区。四、实验方法实现动态分区的分配与回收,主要考虑三个问题:第一、设计记录内存使用情况的数据表格,用来记录空闲区和作业占用的区域(利用结构体类型数组来保存数据);第二、在设计的数据表格基础上设计内存分配算法(采用首次适应算法找合适的分区(对空闲分区表进行排序),分配时要考虑碎片问题);第三、在设计的数据表格基础上设计内存回收算法(分四种情况进行回收(上邻、下邻、上下邻和无相邻分区)。五、实验步骤第一,设计记录内存使用情况的数据表格已分配分区表:起始地址、长度、标志(0表示“空表项”,1表示“已分配”)空闲分区表:起始地址、长度、标志(0表示“空表项”,1表示“未分配”)structused_table{floataddress;//已分分区起始地址floatlength;//已分分区长度,单位为字节intflag;//已分配表区登记栏标志,用0表示空栏目,charzuoyename;};//已分配区表Structfree_table[{floataddress;//空闲分区起始地址floatlength;//空闲分区长度,单位为字节intflag;//空闲分区表登记栏目用0表示空栏目,1表示未配};//空闲分区表第二,在设计的表格上进行内存分配首次适应算法:为作业分配内存,要求每次找到一个起始地址最小的适合作业的分区(按起始地址递增排序)。最大碎片size:要求当找到的空闲分区-作业的大小的值小于或等于size时,将该分区全部分配给作业(数组后面元素向前移);否则,给作业分割出一部分空间时,其余部分仍作为新的空闲分区登记(空闲分区长度=空闲分区长度-作业长度,空闲分区起始地址=空闲分区起始地址+作业长度第三,在设计的表格上进行内存回收。1、上邻:条件:回收作业的始址=某个空闲区的始址+长度操作:空闲区的长度=空闲区的长度+作业的大小2、下邻:条件:回收作业的始址+作业的长度=某个空闲区的始址操作:空闲区的始址=回收作业的始址空闲区的长度=空闲区的长度+作业的长度3、上下邻:条件:1,2条件同时成立操作:空闲区的始址=上邻的始址空闲区的长度=上邻的长度+作业的长度+下邻的长度删除下邻4、无上下邻:操作:找flag=0的行空闲区的始址=回收作业的始址空闲区的长度=作业的长度六、实验代码#includeiostream.h#includeiomanip.h#defineM10//允许的空闲区表长最大为m#defineN10//允许的最大作业数量为n#defineMIN1//碎片的最大值#defineSADDRESS200//空闲分区初始的起始地址#defineSLENGTH150000//空闲分区的初始长度structused_t{floataddress;//已分分区起始地址floatlength;//已分分区长度intflag;//已分配表区登记栏标志,用0表示空栏目}used_table[N];structfree_t{floataddress;//空闲分区起始地址floatlength;//空闲分区长度intflag;//空闲分区表登记栏目用0表示空栏目,1表示未分配}free_table[M];//空闲分区表voidallocate(char,float);//分配算法子程序voidreclaim(char);//回收算法子程序voidmain(){inti,a;floatzyl;charzyn;//空闲分区表初始化free_table[0].address=SADDRESS;//空闲分区表的起始地址free_table[0].length=SLENGTH;//空闲分区表的长度free_table[0].flag=1;//标志位置1表示未分配for(i=1;iM;i++){free_table[i].address=0;free_table[i].length=0;free_table[i].flag=0;}//0表示空栏目//已分分区表初始化for(i=0;iN;i++){used_table[i].address=0;used_table[i].length=0;used_table[i].flag=0;}while(1){cout请选择功能项:endl1-分配主存endl2-回收主存endl3-显示主存endl0-退出endl选择功能项(0-3):;cina;switch(a){case0://当选择0时退出程序return;case1:{//a=1分配主存空间cout\n请输入作业名zyn和作业所需长度zyl(作业名为一个字符,长度zyl要小于SLENGTH):endl;cinzynzyl;allocate(zyn,zyl);//为作业zyn分配主存空间break;}case2:{//a=2回收主存空间cout\n请输入要回收分区的作业名:;cinzyn;reclaim(zyn);//回收作业zyn的主存空间break;}case3:{//a=3显示主存情况,输出空闲区表和已分配区表cout\n输出空闲区表:endl起始地址分区长度标志endl;for(i=0;iM;i++)if(free_table[i].flag!=0)coutsetw(10)free_table[i].addresssetw(10)free_table[i].lengthsetw(10)free_table[i].flagendl;cout\n按任意键,输出已分配区表……;cin.get();cout\n输出已分配区表:endl起始地址分区长度标志endl;for(i=0;iN;i++){if(used_table[i].flag!=0)//输出已分配给作业的表目coutsetw(10)used_table[i].addresssetw(10)used_table[i].lengthsetw(10)(char)used_table[i].flagendl;}break;}default:{cout\n没有该选项!endl;break;}}}cin.get()}//分配算法子程序voidallocate(charzyn,floatzyl){floatad;intk=-1;inti=0;while(iM&&k==-1){//找空间大于zyl的最小空闲区登记项kif(free_table[i].length=zyl&&free_table[i].flag==1)k=i;i++;}if(k==-1){//未找到可用空闲区,返回cout无可用空闲区!endl;return;}/*找到可用空闲区,开始分配:若空闲区大小与作业要求分配的空间差小于MIN,则将找到的空闲区全部分配给该作业;若空闲区大小与要求分配的空间的差大于minisize,则从空闲区划出一部分分配给作业。*/if(free_table[k].length-zyl=MIN){free_table[k].flag=0;ad=free_table[k].address;zyl=free_table[k].length;for(i=k;iM;i++)free_table[i]=free_table[i+1];}else{free_table[k].length=free_table[k].length-zyl;ad=free_table[k].address;free_table[k].address=free_table[k].address+zyl;}/*修改已分配区表*/i=0;while(used_table[i].flag!=0&&iN)i++;//找空表目iused_table[i].address=ad;used_table[i].length=zyl;used_table[i].flag=zyn;return;}//allocate//回收作业名为J的作业所占主存空间voidreclaim(charzyn){inti,k,j,s,t;floatS,L;s=0;while((used_table[s].flag!=zyn||used_table[s].flag==0)&&sN)s++;//找到作业zyn在以分配表中的表目sif(s=N){cout找不到该作业!endl;return;}used_table[s].flag=0;//修改以分配表表目s标志为为空表目S=used_table[s].address;//取作业zyn在内存中的首地址L=used_table[s].length;//取作业zyn所分配到的内存的长度j=-1;k=-1;i=0;//寻找回收分区的上下邻空闲区,上邻表目k,下邻表目jwhile(iM&&(j==-1||k==-1)){if(free_table[i].flag==1){if(free_table[i].address+free_table[i].length==S)k=i;if(free_table[i].address==S+L)j=i;}i++;}if(k!=-1){//有上邻空闲区if(j!=-1){//有下邻空闲区即有上下邻空闲区,三项合并free_table[k].length=free_table[k].length+free_table[j].length+L;free_table[j].flag=0;}else//上邻空闲区,下邻非空闲区,与上邻合并free_table[k].length=free_table[k].length+L;}//ifelse{//k==-1无上邻空闲区if(j!=-1){//无上邻空闲区,有下邻空闲区,与下邻合并free_table[j].address=S;free_table[j].length=free_table[j].length+L;}else{//j==-1上下邻均为非空闲区,回收区域直接填入t=0;//在空闲区表中寻找空栏目while(free_table[t].flag==1&&tM)t++;if(t=M){//空闲区表满,回收空间失败,将已分配区表复原cout主存空闲表没有空间,回收失败!!endl;used_table[s].flag=zyn;return;}free_table[t].address=S;free_table[t].length=L;free_table[t].flag=1;}}for(i=0;i=M-1;i++)for(intj=i;jM;j++)if(free_table[i].addressfree_table[j].address){free_ttemp;temp=free_table[i];free_table[i]=free_table[j];free_table[j]=temp;}}七、实验结果1、总的存储空间2、分配空间3、回收空间
本文标题:计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告
链接地址:https://www.777doc.com/doc-4904554 .html