ImageVerifierCode 换一换
格式:DOCX , 页数:17 ,大小:193.35KB ,
资源ID:2828811      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-2828811.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(操作系统实验模内存管理模拟实验.docx)为本站会员(b****2)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

操作系统实验模内存管理模拟实验.docx

1、操作系统实验模内存管理模拟实验(操作系统原理和linux操作系统相结合的实验)实验四 内存管理模拟实验模拟实现一个简单的固定(可变)分区存储管理系统1实验目的通过本次课程设计,掌握了如何进行内存的分区管理,强化了对首次适应分配算法和分区回收算法的理解。2实验内容(1)建立相关的数据结构,作业控制块、已分配分区及未分配分区(2)实现一个分区分配算法,如最先适应算法、最优或最坏适应分配算法(3)实现一个分区回收算法(4)给定一个作业/进程,选择一个分配或回收算法,实现分区存储的模拟管理图1.流程图3实验步骤首先,初始化函数initial()将分区表初始化并创建空闲分区列表,空闲区第一块的长度是30

2、,以后的每个块长度比前一个的长度长20。frees0.length=30第二块的长度比第一块长20,第三块比第二块长20,以此类推。freesi.length=freesi-1.length+20;下一块空闲区的首地址是上一块空闲区的首地址与上一块空闲区长度的和。freesi.front=freesi-1.front+freesi-1.length;分配区的首地址和长度都初始化为零occupysi.front=0;occupysi.length=0;显示函数show()是显示当前的空闲分区表和当前的已分配表的具体类容,分区的有起始地址、长度以及状态,利用for语句循环输出。有一定的格式,使得输

3、出比较美观好看。assign()函数是运用首次适应分配算法进行分区,从链首开始顺序查找,直至找到一个大小能满足要求的空闲分区为止;然后再按照作业的大小,从该分区中划出一块内存空间分配给请求者,余下的空闲分区仍留在空闲链中。若从链首直至链尾都不能找到一个能满足要求的分区,则此次内存分配失败,返回。这个算法倾向于优先利用内存中低址部分被的空闲分区,从而保留了高址部分的的大空闲区。着给为以后到达的大作业分配大的内存空间创造了条件。它的缺点是低地址部分不断被划分,会留下很多难以利用的、很小的空闲分区,而每次查找又都是从低址部分开始,这样无疑会增加查找可用空闲分区的开销。分配内存,从空闲的分区表中找到所

4、需大小的分区。设请求的分区的大小为job_length,表中每个空闲分区的大小可表示为freei.length。如果freesi.length=job_length,即空闲空间I的长度大于等于作业的长度将空闲标志位设置为1,如果不满足这个条件则输出:“对不起,当前没有满足你申请长度的空闲内存,请稍后再试!”。如果freesi.length=job_length空闲区空间I的长度不大于作业长度,I的值加1判断下一个空闲区空间是否大于作业的长度。把未用的空闲空间的首地址付给已用空间的首地址,已用空间的长度为作业的长度,已用空间数量加1。如果(freesi.lengthjob_length),空间的

5、长度大于作业的长度,freesi.front+=job_length; 空闲空间的起始首地址=原空闲区间的起始长度加作业长度freesi.length-=job_length;空闲区间的长度=原空闲区间的长度-作业的长度。如果空间的长度与作业的长度相等,空闲区向前移一位,空闲区的数量也减一。这样判断所有情况并相应分配之后,内存空间分配成功。 第二个操作为:撤消相应作业。在这个操作中,进行了以下步骤:(1)按照系统提示输入将要撤消的作业名;(2)判断该作业是否存在 若不存在:输出“没有这个作业名,请重新输入作业名”; 若存在:则先分别用flag,start,len保存该作业在分配区表的位置i,内

6、存空间的首地址以及长度。接着根据回收区的首地址,即该作业的首地址,从空闲区表中找到相应的插入点,将其加入空闲表,此时可能出现以下三种情况之一: 1 .回收区只与插入点前一个空闲分区F1相邻接即(freesi.front+freesi.length)=start),此时判断其是否与后一个空闲分区F2相邻接,又分两种情况: 若相邻接,则将三个分区合并,修改新的空闲分区的首地址和长度。新的首地址为F1的首地址,长度为三个分区长度之和,相应的代码为:freesi.length=freesi.length+freesi+1.length+len;,并相应的空闲区表。 若不相邻接,即合并后的首应将回收区与

7、插入点的前一分区合并,则不须为回收分区分配新的表项,只须修改其前一分区的大小。该大小为F1与当前作业大小之和。freesi.length+=len; 2 .回收分区与插入点前一个空闲分区不邻接但与后一空闲分区F2邻接。此时应合并当前作业分区与F2分区,合并后的分区首地址为当前作业首地址start,长度为两个分区长度之和。代码为:freesi.front=start; freesi.length+=len; 3.回收分区既不与插入点前一空闲分区相邻接,也不与后一空闲分区相邻接。此时只须将该回收分区插入空闲区表即可。此时空闲区的数量加1。 将回收区加入空闲区表后还须修改分配区表内容。具体为:修改分

8、配区表中回收区(第一区)之后的各区指针,使其依次前移一位,即occupysi=occupysi+1;同时已分配分区数量减1,即occupy_quantity-; 最后输出内存空间回收完毕!即完成了撤消作业并回收相应空间的操作。图2.初始化空闲分区列表图3.内存空间分配图4.内存回收4实验总结动态分区分配是根据进程的实际需要,动态地为之分配内存空间。程序中采用空闲分区表,用于纪录每个空闲分区的情况。每个空闲分区占一个表目,表目中包括起始地址、长度和状态。采用已分配表,用于存放请求的作业,每个作业占一个表目,包括起始地址、长度和作业名。程序调用initial()函数实现对空闲分区的初始化。将作业装

9、入内存时,运用首次适应分配算法。程序中调用assign()实现,分配内存时,从表首开始查找,直至找到一个大小能满足要求的空闲分区为止;然后再按照作业的大小,从该分区中划出一块内存空间分配给请求者,余下的空闲分区仍留在空闲表中。若不能找到满足要求的空闲区,则此次内存分配失败,返回。回收内存,即撤销某些作业,调用撤销函数cancel(),根据所撤销作业的首址,从空闲区表中找到相应的插入点,回收内存包括四种情况:(1)回收区与前一空闲分区相邻接,此时将回收区与前一分区合并,并修改前一分区的大小;(2)回收区与后一空闲分区相邻接,此时将回收区与后一分区合并,并修改后一分区的首址和大小;(3)回收区同时

10、与前、后分区相邻接,则将三个分区合并,使用前一分区的首址,大小为三分区大小之和;(4)回收区不与空闲分区相邻,则重新建立一新表项,填写首址和大小,插入表中相应位置。函数show()用于显示空闲区表和已分配表时,运用for循环,依次显示每个空闲区表和已分配表的信息。5附录#include#include#include#include#includeconst int MAXJOB=5;/定义表最大记录数typedef struct node int front; int length; char data20;job;/定义job类型的数据类型job freesMAXJOB;/定义空闲区表in

11、t free_quantity;job occupysMAXJOB;/定义已分配区表int occupy_quantity;/初始化并创建空闲分区表函数int initial() int i; frees0.front=0; frees0.length=30; occupys0.front=0; occupys0.length=0; strcpy(frees0.data,free); for(i=1;iMAXJOB;i+) freesi.front=freesi-1.front+freesi-1.length; freesi.length=freesi-1.length+20; strcpy(

12、freesi.data,free); occupysi.front=0; occupysi.length=0; strcpy(occupysi.data, ); free_quantity=MAXJOB; occupy_quantity=0; return 1;/显示函数void show() int i; printf(-n); printf(当前空闲分区表如下:n); printf(起始地址 长度 状态n); for(i=0;ifree_quantity;i+) printf(%5d %8d %sn,freesi.front,freesi.length,freesi.data); prin

13、tf(-n); printf(当前已分配表如下:n); printf(起始地址 长度 占用作业名n); for(i=0;ioccupy_quantity;i+) printf(%5d %6d %sn,occupysi.front,occupysi.length,occupysi.data); printf(-n);/首次适应分配算法void assign() char job_name20; int job_length; int i,j,flag,t; printf(请输入新申请内存空间的作业名和空间大小:); scanf(%s,job_name); scanf(%d,&job_length

14、); flag=0; for(i=0;i=job_length) /如果空闲空间I的长度=作业长度 flag=1; /空闲标志位就置1 if(flag=0) printf(对不起,当前没有能满足你申请长度的空闲内存,请稍候再试!n); else t=0; i=0; while(t=0) /为空闲区间的时候 if(freesi.length=job_length) t=1; i+;/如果空闲空间I的长度不大于作业长度,I加1,判断下一个空间 i-; occupysoccupy_quantity.front=freesi.front;/把未用的空闲空间的首地址付给已用空间的首地址 strcpy(o

15、ccupysoccupy_quantity.data,job_name);/已用空间的内容为作业名 occupysoccupy_quantity.length=job_length;/已用空间的长度为作业的长度 occupy_quantity+; /已用空间数量加1 if(freesi.lengthjob_length) /如果空间的长度大于作业的长度, freesi.front+=job_length; /空闲空间的起始首地址=原空闲区间的起始长度加作业长度 freesi.length-=job_length;/空闲区间的长度=原空闲区间的长度-作业的长度 else /如果空间的长度=作业的

16、长度 for(j=i;jfree_quantity-1;j+) freesj=freesj+1;/空闲区间前移一位 free_quantity-;/空闲区间的数量减一 printf(内存空间分配成功!n); /撤消作业 void cancel() char job_name20; int i,j,flag,p=0; int start; int len; printf(请输入要撤消的作业名:); scanf(%s,job_name); flag=0; for(i=0;ioccupy_quantity;i+) if(!strcmp(occupysi.data,job_name)/当输入作业名匹配

17、时 flag=i;/把i的值赋给flag; start=occupysi.front;/把已用空间的首地址赋给start len=occupysi.length;/把已用空间的长度赋给len if(flag=0) printf(没有这个作业名,请重新输入作业名!n); else /加入空闲表 for(i=0;ifree_quantity;i+) if(freesi.front+freesi.length)=start)/上空 if(i+1)free_quantity)&(freesi+1.front=start+len)/下空 /第i个空闲区间的长度=第i个空闲区间的长度+第i+1个空闲区间的

18、长度(下空闲区)+length freesi.length=freesi.length+freesi+1.length+len; for(j=i+1;jfree_quantity;j+) freesj=freesj+1;/空闲区间前移一位 free_quantity-;/空闲区的数量渐少了一个 p=1; else freesi.length+=len;/(上空下不空)第i个空闲区间的长度=第i个空闲区间的长度+length,空闲区个数不变 p=1; if(freesi.front=(start+len)/下空上不空 freesi.front=start;/起始地址等于待回收地址 freesi.

19、length+=len;/第i个空闲区间的长度=第i个空闲区间的长度+length p=1; if(p=0) /上下空闲区都不空(直接在空闲区表中找一个空表目,将其内容插入) freesfree_quantity.front=start; freesfree_quantity.length=len; free_quantity+; /空闲区的数量加1 /删除分配表中的该作业 for(i=flag;ioccupy_quantity;i+) occupysi=occupysi+1; occupy_quantity-;/已用的区的数量 printf(内存空间回收完毕!n); /主函数void mai

20、n() int flag=0; int t=1; int chioce=0; printf( |-|n); printf( | 可变分区存储管理模拟系统 |n); printf( |-|n); printf( |菜单: (0)退出 |n); printf( | |n); printf( |(1)申请空间 (2)撤消作业 |n); printf( | |n); printf( |(3)显示空闲表和分配表 |n); printf( |-|n); initial(); flag=initial(); while(flag=1) printf(n); printf(请选择:); scanf(%d,&chioce); switch(chioce) case 1: assign(); break; case 2: cancel(); break; case 3: show(); break; case 0: flag=0; break; default: printf(选择错误!);

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2