计算机操作系统动态分区存储管理方式下的内存空间的分配及回收实验报告.doc
《计算机操作系统动态分区存储管理方式下的内存空间的分配及回收实验报告.doc》由会员分享,可在线阅读,更多相关《计算机操作系统动态分区存储管理方式下的内存空间的分配及回收实验报告.doc(15页珍藏版)》请在咨信网上搜索。
. . 计算机操作系统 实验报告 实验二 实验题目:存储器管理 系别:计算机科学与技术系 班级: XX: 学号:2 一、实验目的 深入理解动态分区存储管理式下的存空间的分配与回收。 二、实验容 编写程序完成动态分区存储管理式下的存分配和回收的实现。具体容包括: 确定用来管理存当前使用情况的数据构造; 采用首次适应算法完成存空间的分配; 分情况对作业进展回收; 编写主函数对所做工作进展测试。 三、实验原理 分配:动态分区存储管理式把存除OS占用区域外的空间看作一个大的空闲区。当作业要求装入存时,根据作业需要存空间的大小查询存中各个空闲区,当从存中找到一个大于或等于该作业大小的存空闲区时,选择其中一个空闲区,按作业要求划出一个分区装入该作业。 回收:作业执行完后,它所占用的存空间被收回,成为一个空闲区。如果该空闲区的相邻分区也是空闲区,那么需要将相邻空闲区合并成一个空闲区。 四、实验法 实现动态分区的分配与回收,主要考虑三个问题: 第一、设计记录存使用情况的数据表格,用来记录空闲区和作业占用的区域(利用构造体类型数组来保存数据); 第二、在设计的数据表格根底上设计存分配算法〔采用首次适应算法找适宜的分区〔对空闲分区表进展排序〕,分配时要考虑碎片问题〕; 第三、在设计的数据表格根底上设计存回收算法〔分四种情况进展回收〔上邻、下邻、上下邻和无相邻分区〕。 五、实验步骤 第一,设计记录存使用情况的数据表格 l 已分配分区表:起始地址、长度、标志〔0表示“空表项〞,1表示“已分配〞〕 l 空闲分区表: 起始地址、长度、标志〔0表示“空表项〞,1表示“未分配〞〕 struct used_table { float address; //已分分区起始地址 float length; //已分分区长度,单位为字节 int flag; //已分配表区登记栏标志,用0表示空栏目, char zuoyename; }; //已分配区表 Struct free_table[ { float address; //空闲分区起始地址 float length; //空闲分区长度,单位为字节 int flag; //空闲分区表登记栏目用0表示空栏目,1表示未配 }; //空闲分区表 第二,在设计的表格上进展存分配 l 首次适应算法:为作业分配存,要求每次找到一个起始地址最小的适合作业的分区〔按起始地址递增排序〕。 l 最大碎片size:要求当找到的空闲分区-作业的大小的值小于或等于size时,将该分区全局部配给作业〔数组后面元素向前移〕; l 否那么,给作业分割出一局部空间时,其余局部仍作为新的空闲分区登记〔空闲分区长度=空闲分区长度-作业长度, l 空闲分区起始地址=空闲分区起始地址+作业长度 第三,在设计的表格上进展存回收。 1、上邻:条件:回收作业的始址=某个空闲区的始址+长度 操作:空闲区的长度=空闲区的长度+作业的大小 2、下邻:条件:回收作业的始址+作业的长度=某个空闲区的始址 操作: 空闲区的始址=回收作业的始址 空闲区的长度=空闲区的长度+作业的长度 3、上下邻:条件:1,2条件同时成立 操作:空闲区的始址=上邻的始址 空闲区的长度=上邻的长度+作业的长度+下邻的长度 删除下邻 4、无上下邻: 操作:找flag=0的行 空闲区的始址=回收作业的始址 空闲区的长度=作业的长度 六、实验代码 # include<iostream.h> # include<iomanip.h> #define M 10 //允的空闲区表长最大为m #define N 10 //允的最大作业数量为n #define MIN 1 //碎片的最大值 #define SADDRESS 200 //空闲分区初始的起始地址 #define SLENGTH 150000 //空闲分区的初始长度 struct used_t{ float address; //已分分区起始地址 float length; //已分分区长度 int flag; //已分配表区登记栏标志,用0表示空栏目 }used_table[N]; struct free_t{ float address; //空闲分区起始地址 float length; //空闲分区长度 int flag; //空闲分区表登记栏目用0表示空栏目,1表示未分配 }free_table[M]; //空闲分区表 void allocate(char,float); //分配算法子程序 void reclaim(char); //回收算法子程序 void main(){ int i,a; float zyl; char zyn; //空闲分区表初始化 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){case 0: //中选择0时退出程序 return; case 1: { //a=1 分配主存空间 cout<<"\n请输入作业名zyn和作业所需长度zyl(作业名为一个字符,长度zyl要小于"<<SLENGTH<<"):"<<endl; cin>>zyn>>zyl; allocate(zyn,zyl); //为作业zyn分配主存空间 break; } case 2:{ // a=2 回收主存空间 cout<<"\n请输入要回收分区的作业名:"; cin>>zyn; reclaim(zyn); //回收作业zyn的主存空间 break;} case 3: { //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()}//分配算法子程序 void allocate(char zyn,float zyl) {float ad; int k=-1; int i=0; while(i<M&&k==-1) { //找空间大于zyl的最小空闲区登记项k if(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++; //找空表目i used_table[i].address=ad; used_table[i].length=zyl; used_table[i].flag=zyn; return;}//allocate //回收作业名为J的作业所占主存空间 void reclaim(char zyn){ int i,k,j,s,t; float S,L; s=0; while((used_table[s].flag!=zyn||used_table[s].flag==0)&&s<N) s++; //找到作业zyn在以分配表中的表目s if(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,下邻表目j while(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;}//if else { //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(int j=i;j<M;j++) if(free_table[i].address>free_table[j].address) { free_t temp; temp=free_table[i]; free_table[i]=free_table[j]; free_table[j]=temp; }} 七、实验结果 1、总的存储空间 2、分配空间 3、回收空间 〔1〕有上下邻 〔2〕有上邻 〔3〕有下邻 〔4〕无上下邻,回收7 八、实验总结 1、通过实验学会了理解动态分区存储管理式下的存空间的分配与回收 2、学会了回收的四种式 3、实验过程中遇到了问题,学会了与同学探讨解决 . .word.zl.- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 操作系统 动态 分区 存储 管理 方式 内存空间 分配 回收 实验 报告
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文