




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上【实验目的】目的:1.熟悉主存的分配与回收。2.理解在不同的存储管理方式下,如何实现主存空间的分配与回收。3.掌握动态分区分配方式中的数据结构和分配算法及动态分区存储管理方式及其实现过程。【实验原理】建立两张表,空闲表和已分配表,分别将未分配的作业和已分配好的作业放入其中。当要装入一个作业时,从空闲区表中查找标志为“未分配”的空闲区,从中找出一个能容纳该作业的空闲区。如果找到的空闲区正好等于该作业的长度,则把该分区全部分配给作业。这时应该把该空闲区登记栏中的标志改为“空”,同时在已分配区表中找到一个标志为“空”的栏目登记新装入作业所占用分区的起始地址、长度和作业名。如
2、果找到的空闲区大于作业长度,则把空闲区分成两部分,一部分用来装入作业,另外一部分仍为空闲区。实验采用的是“最优适应”算法。最优适应算法是按作业要求挑选一个能满足作业要求的最小空闲区,这样保证可以不去分割一个大的区域,使装入大作业时比较容易得到满足。此实验为解决假如找到的一个分区可能只比作业所要求的长度略大一点的情况,这时,空闲区分割后剩下的空闲区就很小,这种很小的空闲区往往无法使用,影响了主存的使用。为了一定程度上解决这个问题,如果空闲区的大小比作业要求的长度略大一点,不再将空闲区分成已分分区和空闲区两部分,而是将整个空闲区分配给作业。【实验器材和资料】电脑、Microsoft Visual
3、C+ 6.0软件、操作系统资料书【实验内容和要求】1.主存的分配和回收的实现是与主存储器的管理方式有关的。所谓分配,就是解决多进程如何共享主存空间的问题。所谓回收,就是当进程运行完成时将进程所占的主存空间归还给系统。 2.实验要求使用可变分区存储管理方式,分区分配中所用的数据结构采用空闲分区说明表和空闲分区链表来进行,分区分配中所用的算法采用首次适应算法、循环首次适应算法、最佳适应算法三种算法来实现主存的分配与回收。3.同时,要求设计一个实用友好的可视化用户界面,并显示分配与回收的过程。【实验方法与步骤】1.实验题目:假设初始状态下,可用的内存空间为640KB,并有下列的请求序列: (1)进程
4、1申请130KB(2)进程2申请60K (3)进程3申请100KB(4)进程2释放60KB (5)进程4申请200KB(6)进程3释放100KB (7)进程1释放130KB(8)进程5申请140KB(9)进程6申请60KB (10)进程7申请50KB(11)进程8申请60KB2.实验方法: (1)设计一个空闲分区表,空闲分区表通过空闲分区链表来管理,在进行内存分配时,系统优先使用空闲区低端的空间。(2)设计一个内存分区表,可用链表管理,用以表示当前内存使用情况。(3)设计一个进程申请队列以及进程完成后的释放顺序,实现主存的分配和回收。(4)要求每次分配和回收后把空闲分区的变化情况以及各进程的申
5、请、释放情况以图形方式显示、打印出来。3.实验过程(1)内存分配:动态输入构造空闲区表,并显打印示构造好的空闲分区表。键盘接收内存申请。根据申请,实施内存分配,并返回分配所得内存首址。分配完后,调整空闲分区表(即扣除分配部分),并显示调整后的空闲分区表。若分配失败,返回分配失败信息。(2)内存回收:显示当前的空闲分区表和内存分区表。从键盘接收回收分区的首址与大小,按内存回收的四种情况进行内存回收。 显示回收后已调整好的的空闲分区表。【程序流程图】输入内存最大范围执行操作添加进程并为之分配内存回收进程并回收被进程占用的内存判断是否可以分配退出YES NO发出内存不足的消息【相关数据结构及说明】t
6、ypedef struct None /已分配内存分区链表char name100; /进程名int begin; /开始地址int end; /结束地址int length; /长度大小None *next; /指向下一个内存分区表;typedef struct NeiCun /空闲分区链表int begin1; /空闲分区首地址int end1; /空闲分区尾地址int length1; /空闲分区大小NeiCun *next1; /指向下一个空闲分区表;None *head; /内存分区表头NeiCun *head1; /空闲分区表头int MAXNUMBER; /存储内存空间的最大范围
7、int flag,flog; /标志位【程序代码】 由于我用的是MFC可视化编程编写,所以在这里不能完全复制源代码,只复制几个比较重要的模块的代码。1. 初始化链表 NeiCun *q;MAXNUMBER=m_Max_Edit;head1 = (NeiCun *)malloc(sizeof(NeiCun);head1->next1=NULL;q=(NeiCun *)malloc(sizeof(NeiCun);q->begin1=1;q->end1=m_Max_Edit;q->length1=m_Max_Edit;q->next1=NULL;head1->ne
8、xt1=q;2. 分配内存 None *p1,*p;p1=head;while(p1->next!=NULL)p1=p1->next;p=(None *)malloc(sizeof(None);p->next=NULL;NeiCun *q1,*q2;q1=head1;while(q1->next1!=NULL)if(m_Num_Edit<q1->next1->length1)flag=1;q1->next1->begin1+=m_Num_Edit;q1->next1->length1-=m_Num_Edit;p->begi
9、n=q1->next1->begin1-m_Num_Edit;p->end=p->begin+m_Num_Edit-1;p->length=m_Num_Edit;strcpy(p->name,m_Name1_Edit);p1->next=p; m_ComBo.AddString(p->name);break;else if(m_Num_Edit=q1->next1->length1)flag=1;p->begin=q1->next1->begin1;p->end=q1->next1->end1;p-
10、>length=m_Num_Edit;strcpy(p->name,m_Name1_Edit);p1->next=p;q2=q1->next1;q2->next1=q2->next1; m_ComBo.AddString(p->name);break;elseq1=q1->next1;if(flag=0)AfxMessageBox("内存不足!n不好意思",NULL,MB_OK);3. 回收内存 int k=0;None *p2,*p3;p2=head;while(p2->next!=NULL)if(!strcmp(p2
11、->next->name,m_Name2_Edit)p3=p2->next;p2->next=p3->next;m_ComBo.DeleteString(k);break;k+;p2=p2->next;NeiCun *q1;q1=head1;while(q1->next1!=NULL)if(q1->next1->begin1-1=p3->end)q1->next1->begin1-=p3->length;q1->next1->length1+=p3->length;break;if(q1->n
12、ext1->begin1-1>p3->end)NeiCun *NewProc;NewProc=(NeiCun *)malloc(sizeof(NeiCun);NewProc->begin1=p3->begin;NewProc->end1=p3->end;NewProc->length1=p3->length;NewProc->next1=q1->next1;q1->next1=NewProc;break;if(q1->next1->end1+1=p3->begin)if(q1->next1->
13、next1=NULL)q1->next1->end1+=p3->length;q1->next1->length1+=p3->length; break;elseif(q1->next1->next1->begin1-1=p3->end)q1->next1->length1+=p3->length;q1->next1->length1+=q1->next1->next1->length1;q1->next1->end1+=p3->length;q1->next1-
14、>end1+=q1->next1->next1->length1;NeiCun *pia;pia=q1->next1->next1;q1->next1->next1=pia->next1; break; elseq1->next1->end1+=p3->length;q1->next1->length1+=p3->length; break;q1=q1->next1;AfxMessageBox("该进程已经删除!");4. 描绘内存分区表 HDC hdc;HPEN hp;HBRU
15、SH hbr;hdc=:GetDC(m_hWnd);hp=CreatePen(PS_SOLID,2,RGB(0,0,0);SelectObject(hdc,hp);hbr=CreateSolidBrush(RGB(255,255,255);SelectObject(hdc,hbr);Rectangle(hdc,30,375,480,480); None *pn;pn=head;double x1,y1=375,x2,y2=480; hbr=CreateSolidBrush(RGB(0,0,255);SelectObject(hdc,hbr);while(pn->next!=NULL) x1=(pn->next->begin)/(MAXNUMBER*1.0)*450+30; x2=(pn->next->end)/(MAXNUMBER*1.0)*450+30; Rectangle(hdc,x1,y1,x2,y2); pn=pn->next;DeleteObject(hbr);【执行结果图示】1. 输入640KB内存总大小,并添加进程PM1,申请内存为130KB2. 添加进程PM2,申请内存60KB3添加进程PM3,申请内存100KB4.回收进程PM25.添加进程PM4,申请内存200以上
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 土木工程材料模考试题+参考答案
- 个人工作实习心得体会
- 单独中介合同范本
- 兑房押金合同范例
- epc合同和总包合同范本
- 三年级下学期语文教学总结
- 中式烹调师中级练习题及参考答案
- 养殖蚯蚓合同范本
- 单独招生机电类复习题
- 七色花幼儿教学反思
- 高速公路改扩建工程路基标准化
- 海关监管场所投资建设项目可行性研究报告-广州中撰咨询
- 六氟化硫(SF6)气体的管理及充注质量检查表
- 一年级劳动课教案设计
- Windows Azure云平台基本操作手册
- 中南大学-钢结构门式钢架厂房毕业设计
- 百家姓精品资源课件
- 医院感染控制原则
- T∕ASC 17-2021 电动汽车充换电设施系统设计标准
- 水闸设计步骤计算书(多表)
- 智慧安监重大危险源监管平台解决方案
评论
0/150
提交评论