计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告_第1页
计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告_第2页
计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告_第3页
计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告_第4页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

.. .. ..计算机操作系统实验报告实验二实验题目:存储器管理系别:计算机科学与技术系班级:姓名:专业.专注 ... .. ..学号: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的行空闲区的始址=回收作业的始址专业.专注 ... .. ..空闲区的长度=作业的长度六、实验代码#include<iostream.h>#include<iomanip.h>#defineM10 //允许的空闲区表长最大为 m#defineN10 //允许的最大作业数量为 n#defineMIN1 //碎片的最大值#defineSADDRESS200 //空闲分区初始的起始地址#defineSLENGTH 150000 //空闲分区的初始长度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;i<M;i++){ free_table[i].address=0;free_table[i].length=0;free_table[i].flag=0;} //0表示空栏目已分分区表初始化for(i=0;i<N;i++){ used_table[i].address=0;used_table[i].length=0;used_table[i].flag=0;}while(1){cout<<" 请选择功能项:"<<endl<<"1-分配主存"<<endl<<"2-回收主存"<<endl<<"3-显示主存"<<endl<<"0-退出"<<endl专业.专注 ... .. ..<<"选择功能项(0-3):";cin>>a;switch(a){case0: //当选择0时退出程序return;case1:{ //a=1 分配主存空间cout<<"\n 请输入作业名zyn和作业所需长度zyl(作业名为一个字符,长度zyl要小于"<<SLENGTH<<"):"<<endl;cin>>zyn>>zyl;allocate(zyn,zyl); //为作业zyn分配主存空间break;}case2:{ //a=2 回收主存空间cout<<"\n 请输入要回收分区的作业名 :";cin>>zyn;reclaim(zyn); //回收作业zyn的主存空间break;}case3:{ //a=3 显示主存情况,输出空闲区表和已分配区表cout<<"\n 输出空闲区表:"<<endl<<" 起始地址 分区长度 标志"<<endl;for(i=0;i<M;i++)if(free_table[i].flag!=0)cout<<setw(10)<<free_table[i].address<<setw(10)<<free_table[i].length专业.专注 ... .. ..<<setw(10)<<free_table[i].flag<<endl;cout<<"\n 按任意键,输出已分配区表⋯⋯";cin.get();cout<<"\n 输出已分配区表:"<<endl<<" 起始地址 分区长度 标志"<<endl;for(i=0;i<N;i++){if(used_table[i].flag!=0)// 输出已分配给作业的表目cout<<setw(10)<<used_table[i].address<<setw(10)<<used_table[i].length<<setw(10)<<(char)used_table[i].flag<<endl;}break;}default:{cout<<"\n 没有该选项!"<<endl;break;}}}cin.get()}//分配算法子程序voidallocate(charzyn,floatzyl){ floatad;intk=-1;inti=0;while(i<M&&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;i<M;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&&i<N) 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)&&s<N)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(i<M&&(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&&t<M)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;j<M;j++)if(free_table[i].address>free_tab

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论