




已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验报告 实验课程名称 动态内存分配算法 专 业 计算机科学与技术 班 级 姓 名 学 号 实验学时 指导教师 成 绩 年12月1日 实验报告 专业 计算机科学 与技术 班级姓名学号 实验课 程 操作系统 指导教 师 实验日 期 同实验 者 实验项 目 动态内存分配算法 实验设 备及器 材 PC机一台 VC 6 0 一 实验内容与要求 动态分区分配又称为可变分区分配 它是根据进程的实际需要 动态地为之分 配内存空间 在实验中运用了三种基于顺序搜索的动态分区分配算法 分别是1 首次适应算法2 循环首次适应算法3 最佳适应法3 最坏适应法分配主存空间 二 需求分析 本次实验通过C语言进行编程并调试 运行 显示出动态分区的分配方式 直 观的展示了首次适应算法循环首次适应算法 最佳适应算法和最坏适应算法对 内存的释放和回收方式之间的区别 首次适应算法 要求空闲分区链以地址递增的次序链接 在分配内存时 从链首开始顺序查找 直至找到一个大小能满足要求的空闲分区为止 然后在按照作业的大小 从 该分区中划出一块内存空间 分配给请求者 余下的空余分区仍留在空链中 优点 优先利用内存中低址部分的空闲分区 从而保留了高址部分的大空闲区 为以后到达的大作业分配大的内存空间创造了条件 缺点 低址部分不断被划分 会留下许多难以利用的 很小的空闲分区即碎片 而每次查找又都是从低址部分开始的 这无疑又会增加查找可用空闲分区时 的开销 循环首次适应算法 在为进程分配内存空间时 不是每次都从链首开始查找 而是从上次找到的空 闲分区的下一个空闲分区开始查找 直到找到一个能满足要求的空闲分区 优点 该算法能使内存中的空闲分区分布得更均匀 从而减少了查找空闲分区 时的开销 最佳适应算法 该算法总是把能满足要求 又是最小的空闲分区分配给作业 避免大材小用 该算法要求将所有的空闲分区按其容量以从小到大的顺序形成一空闲分区链 缺点 每次分配后所切割下来的剩余部分总是最小的 这样 在存储器中会留 下许多难以利用的碎片 最坏适应算法 最坏适应算法选择空闲分区的策略正好与最佳适应算法相反 它在扫描整个空 闲分区或链表时 总会挑选一个最大的空闲区 从中切割一部分存储空间给作 业使用 该算法要求 将所有的空闲分区 按其容量以大到小的顺序形成一空 闲分区链 查找时 只要看第一个分区能否满足作业要求即可 优点 可使剩下的空闲区不至于太小 产生碎片的可能性最小 对中小作业有 利 同时 最坏适应算法查找效率很高 缺点 导致存储器中缺乏大的空闲分区 三 数据结构 为了实现动态分区分配算法 系统中配置了相应的数据结构 用以描述空闲分 区和已分配分区的情况 常用的数据结构有空闲分区表和空闲分区链 流程图 当一个新作业要求装入主存时 必须查空闲分区表 从中找出一个足够大的空 闲区 若找到的空闲区大于作业需要量 这时应把它分成两部分 一部分为占 用区 另一部分为空闲区 当一个作业撤离时 归还的区域如果与其他空闲区相邻 则合并成一个较大的 空闲区 登录在空闲区表中 四 功能实现四 功能实现 五 心得体会 通过本次实验 对动态内存分配的相关知识有了更深的认识 中途也遇到了许 多困难 但幸运的是最终的顺利的解决并完成了此次试验 也更加熟练地掌握 了关于内存分配的使用 六 源代码六 源代码 include using namespace std int FreePartition 100 空闲分区块数组 int FirstPartition 100 首次适应算法数组 int CycleFirstPartition 100 循环首次适应算法数组 int BestPartition 100 最佳适应算法数组 int WorstPartition 100 最坏适应算法数组 int ProcessNeed 100 每个作业的大小 int PartitionNum ProcessNum 分区块数 作业数 首次适应算法 void First int i j char str for i 0 i PartitionNum i FirstPartition i FreePartition i for i 0 i ProcessNum i 找出第一块满足作业的分区 for j 0 jFirstPartition j continue else FirstPartition j ProcessNeed i 找到后把分区大小减去作业的大小 str A i cout 作业 str 在第 j 1 块分区中 endl break cout endl cout 分配之后剩余情况 endl for i 0 i PartitionNum i cout FirstPartition i cout endl endl 循环首次适应算法 void CycleFirst int i j 1 char str for i 0 i PartitionNum i CycleFirstPartition i FreePartition i for i 0 i ProcessNum i for j 0 j PartitionNum j j j 1 while jCycleFirstPartition j continue j else CycleFirstPartition j ProcessNeed i str A i cout 作业 str 在第 j 1 块分区中 endl break j cout j if j PartitionNum cout endl cout 分配之后剩余情况 endl for i 0 i PartitionNum i cout CycleFirstPartition i cout endl endl 最佳适应算法 void Best int i j k char str for i 0 i PartitionNum i BestPartition i FreePartition i for i 0 i ProcessNum i k 0 for j 0 j PartitionNum j cout BestPartition j ProcessNeed i ProcessNeed i k j break for int n 0 n PartitionNum n if BestPartition n ProcessNeed i 找最佳的 k n BestPartition k ProcessNeed i str A i cout 作业 str 在第 j 1 块分区中 endl cout endl cout 分配之后剩余情况 endl for i 0 i PartitionNum i cout BestPartition i cout endl endl 最坏适应算法 void Worst int i j k char str for i 0 i PartitionNum i WorstPartition i FreePartition i for i 0 i ProcessNum i k 0 for j 0 jWorstPartition k 找到最大的分区 k j WorstPartition k ProcessNeed i str A i cout 作业 str 在第 j 1 块分区中 endl cout endl cout 分配之后剩余情况 endl for i 0 i PartitionNum i cout WorstPartition i cout endl endl void main int i cout 输入分区块数 PartitionNum cout 输入每个分区的大小 endl for i 0 i FreePartit
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 工业互联网应用案例解析与企业数字化转型实践经验分享
- 浙江省浙南名校联盟2025-2026学年高二上学期开学联考历史试卷
- 运城市小学考试试题及答案
- 2025年石油公司加油站人员安全操作知识考试题(附含答案)
- 2025年公共文秘教程考试题及答案
- 2025年山西省长治市事业单位工勤技能考试题库(含答案)
- 2025年山东省淄博市事业单位工勤技能考试考试题库及参考答案
- CN120111859A 一种散热组件及电子设备 (南昌华勤电子科技有限公司)
- U型吊安全事故培训课件
- CN120105831B 一种电机铁芯冲压模具装配面高保真快速建模方法及系统 (杭州电子科技大学)
- 初三上期开学收心教育班会
- 工会招聘考试试题及答案
- 小学四年级上册语文学历案 教学设计
- 2025北京九年级(上)期末语文汇编:句子默写
- 无人机遥感技术在农业中应用解决方案
- 检验科三基培训
- 涉爆人员培训内容
- 《内科学》课件-5.心律失常
- 2025年全国中学生汉字听写大会比赛题库及解析(共四套)
- 心电图室危急值报告制度
- 殡仪馆面试题及答案
评论
0/150
提交评论