博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
12.30
阅读量:4359 次
发布时间:2019-06-07

本文共 1560 字,大约阅读时间需要 5 分钟。

一. 实验目的

为了合理地分配和使用这些存储空间,当用户提出申请主存储器空间时,存储管理必须根据申请者的要求,按一定的策略分析主存空间和使用情况,找出足够的空闲区域给申请者。当作业撤离归还主存资源时,则存储管理要收回占用的主存空间。主存的分配和回收的实现是与主存储器的管理方式有关的,通过本实验帮助我们理解在不同的存储管理方式下应怎样实现主存空间的分配和回收。

用高级语言完成一个主存空间的分配和回收模拟程序,以加深对内存分配方式及其算法的理解。

二. 实验内容

2.1 模拟包括3部分:

1) 实现特定的内存分配算法

2) 实现内存回收模拟

3) 每种内存分配策略对应的碎片数统计 

2.2 固定分区存储管理: 

假设内存容量为120KB,并且分别划分成23,24,25,26KB大小的块各一块。

一个进程所需要的内存为0到100个KB。同时假设一个进程在运行过程中所需内存的大小不变。

模拟五个进程到达请求分配与运行完回收情况,输出主存分配表.

2.3 动态分区分配存储管理

采用连续分配方式之动态分区分配存储管理,使用首次适应算法、下次适应算法、最佳适应算法和最坏适应算法4种算法完成设计(任选两种算法)。

(1)在程序运行过程,由用户指定申请与释放。

(2)设计一个已占用分区表,以保存某时刻主存空间占用情况。

(3)设计一个空闲分区表,以保存某时刻主存空间剩余情况。

(4)用两个表的变化情况,反应各进程所需内存的申请与释放情况。

3. 实验环境

根据指定的实验课题,完成设计、编码和调试工作,完成实验报告。

可以选用Turbo C作为开发环境。也可以选用Windows下的VB,CB或其他可视化环境,利用各种控件较为方便。自主选择实验环境。

三、 实验方法、步骤及结果测试

#include"stdio.h"#include"stdlib.h"#define n 10 /*假定系统允许的最大作业为n,假定模拟实验中n值为10*/#define m 10 /*假定系统允许的空闲区表最大为m,假定模拟实验中m值为10*/#define minisize 100struct{ float address; /*已分分区起始地址*/    float length; /*已分分区长度,单位为字节*/    int flag; /*已分配区表登记栏标志,用"0"表示空栏目*/}used_table[n]; /*已分配区表*/struct{ float address; /*空闲区起始地址*/ float length; /*空闲区长度,单位为字节*/ int flag; /*空闲区表登记栏标志,用"0"表示空栏目,用"1"表示未分配*/}free_table[m]; /*空闲区表*/void main( ){ int i,a; void allocate(char str,float leg);//分配主存空间函数 void reclaim(char str);//回收主存函数 float xk; char J;/*空闲分区表初始化:*/ free_table[0].address=10240; free_table[0].length=102400; free_table[0].flag=1; for(i=1;i
=leg) { fflag=1;break; } } if(fflag==0) printf("没有满足条件的空闲区\n"); else { ressize=free_table[i].length-leg; for(k=0;k

 

 

转载于:https://www.cnblogs.com/WuminH/p/5089035.html

你可能感兴趣的文章
Python中type和object
查看>>
linux-nohup命令
查看>>
FetchAPI 的使用
查看>>
WPF框架MVVM简单例子
查看>>
bzoj 1996: [Hnoi2010]chorus 合唱队
查看>>
PHP加文字水印时报错 imagettftext() [function.imagettftext]: any2eucjp()
查看>>
c# 7.0 6.0 新语法
查看>>
[LeetCode OJ] Roman to Integer
查看>>
VIM vim/vi的文件内、跨文件复制粘贴操作、替换操作
查看>>
彻底解决eslint与webstorm针对vue的script标签缩进处理方式冲突问题
查看>>
默然回首繁忙而充实的2016
查看>>
浅谈this关键字
查看>>
jdbc驱动加载
查看>>
来了解一下Mysql索引的相关知识:基础概念、性能影响、索引类型、创建原则、注意事项...
查看>>
lecture15-自动编码器、语义哈希、图像检索
查看>>
PHP不能创建csv中文名文件
查看>>
Unity3d优化
查看>>
Git 常用命令
查看>>
POJ 3204 网络流的必须边
查看>>
看无可看 分治FFT+特征值方程
查看>>