下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验二 主存储器空间的分配和回收1、 实验内容主存储器空间的分配和回收。2、 实验目的计算机系统不仅要有足够容量、存储速度高、稳定可靠的主存储器,而且要能合理的分配和使用者且存储空间。主存的分配和回收的实现是与主存储器的管理方式有关的。本实验有助于了解在不同的存储管理方式下,应怎样实现主存空间的分配和回收。3、 实验题目在可变分区管理方式下,采用最先适应算法实现主存空间的分配和回收。4、 数据结构struct Block /空闲链结构体 string name; /作业名 int address; /分区首地址 int size; /分区大小 int state; /分区转态 struct B
2、lock *next; /前向指针 struct Block *front; /后向指针 ; 构造一个空闲链struct Used /已分配分区结构体 Block *usedArea; Used *next; ;分配分区结构体void Allocate(string reqName,int reqSize) /分配函数 Block *p=freeHead-front ; Used *r1,*r2;while(p!=NULL) if(reqSizesize) /如果请求的分区的大小小于一个空闲分区的大小 Used *temp=new Used; temp-usedArea =p; Block *
3、q=new Block; *q=*p; temp-usedArea -name =reqName; temp-usedArea -size =reqSize; temp-usedArea -front =q; temp-usedArea -state =1; q-size =q-size -reqSize; q-address =q-address + reqSize; q -next-front=q; if(q -front!=NULL) q -front-next=q; r1=usedHead; r2=usedHead-next; while(r2!=NULL&r2-usedArea-ad
4、dressusedArea-address) r1=r2;r2=r2-next; r1-next=temp; temp-next=r2; break; else if(reqSize=p-size)/如果请求的分区的大小等于一个空闲分区的大小 Used *temp=new Used; temp-usedArea =p; temp-usedArea -name =reqName; temp-usedArea -state =1; p-next-front =p-front ; if(p-front!=NULL) p-front -next =p-next ; r1=usedHead; r2=us
5、edHead-next; while(r2!=NULL&r2-usedArea-addressusedArea-address) r1=r2;r2=r2-next; r1-next=temp; temp-next=r2; break; p=p-front;构建一个链表,实现内存分配。5、 源程序#include #include using namespace std; struct Block /空闲链结构体 string name; /作业名 int address; /分区首地址 int size; /分区大小 int state; /分区转态 struct Block *next; /
6、前向指针 struct Block *front; /后向指针 ; struct Used /已分配分区结构体 Block *usedArea; Used *next; ; Block *freeHead; / 带表头附加节点的空闲链头指针 Used *usedHead; /带表头附加结点的已分配分区头指针 bool InitValue() /初始化函数 cout本程序设立的操作功能:1-申请资源 2-释放资源 3-打印信息size=0; freeHead-next=NULL; freeHead-state=1; usedHead=new Used; Block *p=new Block; p
7、-address=0; usedHead-usedArea=p; usedHead-next=NULL; Block *temp=new Block; cout请先输入主存大小(k):temp-size; temp-address=0; temp-state =0; temp-next=freeHead; temp-front=NULL; freeHead-front=temp; return true; void Display(Block *p,Used *q) /打印信息的函数 cout已分配分区信息(作业,始址,大小):endl; while(q!=NULL) coutusedArea
8、-name,usedArea-address,usedArea-sizenext; cout空闲链分区信息(始址,大小):endl; while(p!=NULL) coutaddress,; coutsizefront; void Allocate(string reqName,int reqSize) /分配函数 Block *p=freeHead-front ; Used *r1,*r2; while(p!=NULL) if(reqSizesize) /如果请求的分区的大小小于一个空闲分区的大小 Used *temp=new Used; temp-usedArea =p; Block *q
9、=new Block; *q=*p; temp-usedArea -name =reqName; temp-usedArea -size =reqSize; temp-usedArea -front =q; temp-usedArea -state =1; q-size =q-size -reqSize; q-address =q-address + reqSize; q -next-front=q; if(q -front!=NULL) q -front-next=q; r1=usedHead; r2=usedHead-next; while(r2!=NULL&r2-usedArea-add
10、ressusedArea-address) r1=r2;r2=r2-next; r1-next=temp; temp-next=r2; break; else if(reqSize=p-size)/如果请求的分区的大小等于一个空闲分区的大小 Used *temp=new Used; temp-usedArea =p; temp-usedArea -name =reqName; temp-usedArea -state =1; p-next-front =p-front ; if(p-front!=NULL) p-front -next =p-next ; r1=usedHead; r2=use
11、dHead-next; while(r2!=NULL&r2-usedArea-addressusedArea-address) r1=r2;r2=r2-next; r1-next=temp; temp-next=r2; break; p=p-front; if(p=NULL) cout资源不足 请等待next,*r=usedHead; Block *q; while(p!=NULL) if(p-usedArea-name=freeName)/找到同名的作业后,再分四种情况讨论 q=p-usedArea; int flag1=1,flag2=1; Block *p1=freeHead-front
12、; Block *pfront,*pnext; while(p1-addressaddress) if(p1-address+p1-size=q-address)flag1=0;pnext=p1; p1=p1-front; if(q-address+q-size=p1-address) flag2=0;pfront=p1; if(flag1=0) if(flag2=0) pnext-front =pfront-front; pnext-size=pnext-size + q-size + pfront-size; if(pfront-front!=NULL) pfront -front -ne
13、xt=pnext; r-next =p-next; else pnext -size +=q-size;r-next =p-next ; else if(flag2 =0) pfront -address -=q-size; pfront -size +=q-size ; r-next =p-next ; else Block *temp=freeHead; while(temp-address address )temp=temp-front; q-front =temp; q-next =temp-next ; q-next-front =q; temp-next =q; q-state =0; r-next =p-next ; break; r=p; p=p-next ; int main() InitValue(); int operate;/操作符1-申请资源 2-释放资源 3-打印信息 string name; int size; while(1) cout请选择操作
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 市场营销活动效果评估工具与案例分析模板
- 转款事宜跟进确认函(5篇)
- 工程安全质量保障承诺书8篇范文
- 医疗设备质量合规承诺书8篇
- 年度工作总结通报函(7篇)
- 护理质量管理与改进
- 生产成本控制及核算工具集
- 客户数据隐秘保护承诺函7篇
- 护理实验中的药物注射技术
- 不断优化品质提升承诺书(3篇)
- 2026年陕西工业职业技术学院单招职业技能测试题库带答案详解(新)
- 2026届湖北省武汉市高三三月调研考试英语试卷(含答案)
- 2026广东茂名市公安局茂南分局招聘警务辅助人员20人考试参考题库及答案解析
- 三年(2023-2025)湖北中考语文真题分类汇编:专题09 名著阅读(解析版)
- 市域产教联合体绩效考核体系制度
- 2026秋招:阿里巴巴面试题及答案
- 2026年及未来5年中国激光设备行业市场前景预测及投资战略研究报告
- 2026年演出经纪人考试题库含答案(考试直接用)
- 清廉社区制度规范
- 2026华泰证券招聘面试题及答案
- 农村宅基地执法培训课件
评论
0/150
提交评论