已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验 可变分区内存分配首次适应算法模拟一、实验目的:模拟内存分配, 了解并掌握动态分区分配中所用的数据结构、分区分配算法,深刻理解首次适应内存分配算法。二、实验内容:#include #include #include int const total= 200 ; /内存总数int const beginaddress = 20;/初次分配起始地址struct Blockint addr; /块的起始地址int size; / 块的大小int flag; /块的分配状态 1:代表已分配 0:代表未分配;block100;int count=0; /块的个数,初值为0,分配一个则加1,减少一个则减1void display() /显示所有块的模块 int i;printf( 目前内存情况n);printf(- n);printf( 块号 起始地址 大小 分配状态n);for(i=1;i=count;i+)printf( %d %d %d ,i,blocki.addr,blocki.size); if (blocki.flag=0)printf(未分配n);elseprintf(已分配n);printf(- n);void jinchengFirstEnter() /首次初始化分配模块 printf(内存总数为%d 第一次分配从 %d 开始n,total,beginaddress);int i=1; int size;int geshu;printf(请输入要初次调入内存的进程的个数:);scanf(%d,&geshu); while(i=geshu) printf(请输入第%d个进程的大小:,i); scanf(%d,&size); count+; if (count=1) blockcount.addr=beginaddress ; else blockcount.addr=blockcount-1.addr+blockcount-1.size; blockcount.size=size; blockcount.flag=1; i+; count+; blockcount.addr=blockcount-1.addr+blockcount-1.size; blockcount.flag=0; blockcount.size=total-blockcount.addr;void jinchengEnter()/自己编写,采用首次适应算法void jinchengExit() /作业调出内存模块 int kuaihao; printf(请输入要调出内存的块号:); scanf(%d,&kuaihao);if(blockkuaihao.flag=0)printf(该块内存是空闲的,无需调出n);else / 将该块设为空闲,就是将该块的flag设为0,/还考虑了该块的下一块如果是空闲的,则将这两块合并为一块,总块数减1/如果要考虑该块的前一块是空闲,则将这两块合并为一块,总块数减1,如何改代码?blockkuaihao.flag=0;if(blockkuaihao+1.flag=0)blockkuaihao.size=blockkuaihao.size+blockkuaihao+1.size;for(int i=kuaihao+2;i=count;i+)blocki-1=blocki;blockcount.size=0;blockcount.flag=0;blockcount.addr=0;count-;display();void main()int flag=0,select;jinchengFirstEnter(); display();while(flag=0) printf( 请输入相应操作n); printf( 1. 进程进入内存 n); printf( 2. 进程退出内存n); printf( 3. 显示当前状态n); printf( 4. 退出); printf(n n 请选择:); scanf(%d,&select); switch(select) case 1:jinchengEnter();break; case 2:jinchengExit();break; case 3:display(); break; case 4:flag=1;break; default: printf(选择错误,请重新选择); 要求:1. 仔细研读上述代码,体会可变分区分配的模拟实现,实验报告上描述出jinchengFirstEnter()函数的实现思想,2. jinchengFirstEnter()函数没有考虑输入的数据超过范围的情况,请完善该函数3. 在进程退出函数jinchengExit()中考虑不全面,具体看函数中的描述,能否改写使得函数完整?下面是附加题。4. 请自己实现jinchengEnter()函数,该函数是模拟某进程进入内存,按首次适应算法寻找空闲空间函数功能提示:首先输入要调入内存的进程的大小。然后在block数组中找未分配且比该进程大的块,如找到的块和进程一样大,直接将该块设为已分配,如比进程大,该块要分为两块,一块已分配,一块空闲,并且后面的块依次后移一位。#include #include #include int const total= 200 ; /内存总数int const beginaddress = 20;/初次分配起始地址struct Blockint addr; /块的起始地址int size; / 块的大小int flag; /块的分配状态 1:代表已分配 0:代表未分配;block100;int count=0; /块的个数,初值为0,分配一个则加1,减少一个则减1void display() /显示所有块的模块 int i;printf( 目前内存情况n);printf(- n);printf( 块号 起始地址 大小 分配状态n);for(i=1;i=count;i+)printf( %d %d %d ,i,blocki.addr,blocki.size); if (blocki.flag=0)printf(未分配n);elseprintf(已分配n);printf(- n);void jinchengFirstEnter() /首次初始化分配模块 printf(内存总数为%d 第一次分配从 %d 开始n,total,beginaddress);int i=1; int size;int geshu;int total1=0;printf(请输入要初次调入内存的进程的个数:);scanf(%d,&geshu); while(i20&total1200) printf(重新输入); scanf(%d,&size); total1=size+total; count+; if (count=1) blockcount.addr=beginaddress ; else blockcount.addr=blockcount-1.addr+blockcount-1.size; blockcount.size=size; blockcount.flag=1; i+; count+; blockcount.addr=blockcount-1.addr+blockcount-1.size; blockcount.flag=0; blockcount.size=total-blockcount.addr;void jinchengEnter()/自己编写,采用首次适应算法void jinchengExit() /作业调出内存模块 int kuaihao; printf(请输入要调出内存的块号:); scanf(%d,&kuaihao);if(blockkuaihao.flag=0)printf(该块内存是空闲的,无需调出n);else / 将该块设为空闲,就是将该块的flag设为0,/还考虑了该块的下一块如果是空闲的,则将这两块合并为一块,总块数减1/如果要考虑该块的前一块是空闲,则将这两块合并为一块,总块数减1,如何改代码?blockkuaihao.flag=0;if(blockkuaihao+1.flag=0)blockkuaihao.size=blockkuaihao.size+blockkuaihao+1.size;for(int i=kuaihao+2;i=count;i+)blocki-1=blocki;blockcount.size=0;blockcount.flag=0;blockcount.addr=0;count-;if(blockkuaihao-1.flag=0) blockkuaihao.size=blockkuaihao.size+blockkuaihao-1.size;for( int i=kuaihao+2;i=count;i+)blocki+1=blocki-1; blockcount.size=0;blockcount.flag=0;blockcount.addr=0;count-;display();void main()int flag=0,select;jinchengFirstEnter(); display();while(flag=0) printf( 请输入相应操作n); printf( 1. 进程进入内存 n); printf( 2. 进程退出内存n); printf( 3. 显示当前
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年黑龙江省经济管理干部学院马克思主义基本原理概论期末考试模拟试卷
- 跨学科融合视角下智能研修模式教师学习成果转化路径探析教学研究课题报告
- 2024年吉林师范大学博达学院马克思主义基本原理概论期末考试真题汇编
- 2025年重庆城市职业学院马克思主义基本原理概论期末考试笔试题库
- 2024年首都经济贸易大学马克思主义基本原理概论期末考试笔试真题汇编
- 2025年国家开放大学马克思主义基本原理概论期末考试笔试真题汇编
- 2025年沧州交通学院马克思主义基本原理概论期末考试参考题库
- 2024年广西金融职业技术学院马克思主义基本原理概论期末考试真题汇编
- 2025年大理农林职业技术学院马克思主义基本原理概论期末考试笔试题库
- 2025年西安体育学院马克思主义基本原理概论期末考试真题汇编
- 教师三笔字培训课件
- 党的二十届四中全会精神丨线上知识有奖竞答题库
- 工程项目施工管理工作流程
- 房地产开发公司建立质量保证体系情况说明
- 数学课如何提高课堂教学容量
- 伤口造口院内专科护士护理考核试题与答案
- JJF 1759-2019衰减校准装置校准规范
- 群文阅读把数字写进诗
- 医用设备EMC培训资料课件
- 锅炉防磨防爆工作专项检查方案
- 气田后期开发技术负压采气技术
评论
0/150
提交评论