- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第6次实验
请注意:
本次实验最低要求为提交详细算法流程图和步骤说明
第六次实验 内存分配与回收模拟
1.实验目的
通过使用位图跟踪内存使用情况,模拟和评价不同的内存分配算法;熟悉设计思想、数据定义、处理流程、源、运行结果、体会等部分显示出每次分配和回收后的空闲分区链的情况来以及内存占用情况图
图 1 回收进程X的内存是与相邻区的四种组合
程序执行示例:
6.部分参考代码
1)关于内存分配的函数可以设计为以下3个
当然,具体函数设计跟你的数据表格设计密切相关
2)另一种数据表格设计对应的部分代码【C++】
#include iomanip
#include iostream
#define M 20
#define N 20
using namespace std;
//假定最大空闲分区20个,内存中同时最多可容纳的作业数20个
struct empty//空闲分区表
{
int address_of_start; //起始地址
int size_of_empty; //空闲大小,依据分配单元考虑,即大小为分配单元数而非实际字节数
int yesorno; //是否空闲,1 空闲,有效
} Empty[M];
struct not_empty//已分配分区表
{
int process_id;//作业标志符,此处采用0-255的整数
int address_of_start;//起始地址
int size_of_notempty;//作业请求的内存单元数
int yesorno; //是否已分配,1 已分配 有效
} Not_Empty[N];
int CountOfEmpty=1,CountOfNotEmpty=0; //假定从0时刻开始,最初内存中没有作业
int Max_Size = 128; //最大空间128 X 2kb = 256kb
int Num_Of_Row = 11; //显示时,横排个数
int Num_of_Holes =0; //碎片空闲区个数
int Time[N]={1};//进程分配搜索空闲区次数
int enough(int Size_Of_NotEmpty) //判断是否存在可分配给新作业的空闲区
{
int i;
for (i=0;iCountOfEmpty;i++) //首次适配 first fit
{
if (Empty[i].size_of_empty = Size_Of_NotEmpty )
return i;
else
Time[num]+=1;
}
num++;
return -1;
}
int fenpei()
{
int temp,i;
CountOfNotEmpty += 1;
Not_Empty[CountOfNotEmpty].yesorno = 0;
for (i=0;iCountOfNotEmpty;i++)
if (Not_Empty[i].yesorno == 0)
{
cout输入进程ID (0 ~ 255),占用空间大小(0 ~ 10)\n;
cinNot_Empty[i].process_idNot_Empty[i].size_of_notempty;
if (Not_Empty[i].process_id 0 || Not_Empty[i].process_id 255)
{
CountOfNotEmpty -= 1;
cout进程号 0 ~ 255\n;
return -1;
}
for (int ii=0;iiCountOfNotEmpty;ii++)
{
if (Not_Empty[i].process_id == Not_Empty[ii].process_id i!= ii)
{
CountOfNotEmpty -= 1;
cout进程号必须唯一\n;
return -1;
}
}
temp = enough(Not_Empty[i].size_of_notempty);
if (temp = 0) //找到了能满足请求的空闲分区
{
Not_Empty[i].address_of_start = Empty[temp].address_of_start;
Not_Empty[i].yesorno = 1;
Empty[temp].address_of_start += Not_Empty[i].size_of_notempty;
Empty[temp].size_of_empty -= Not
您可能关注的文档
- 瑜珈其实并不复杂.doc
- 瑜伽鸽王式并不难?这样练习你也可以,没有难只有不行!.pdf
- 瑞典斯德哥尔摩别致的诺比斯酒店.pdf
- 瑞凌股份:首次公开发行股票并在创业板上市公告书 2010-12-28.pdf
- 瑞普生物:首次公开发行股票并在创业板上市上市公告书 2010-09-16.pdf
- 瑞普生物:首次公开发行股票并在创业板上市初步询价及推介公告 2010-08-27.pdf
- 生物质水煤浆制浆燃烧集成系统技术经济分析_刘建文.pdf
- 用户索赔315元并要求诺基亚为错字道歉.pdf
- 用平底锅给家人做一款低脂饼干.pdf
- 由深圳市三本化工有限公司生产经营的优质工业涂料.pdf
- 2025年学期新统编版七年级上册道德与法治课件 10.2 滋养心灵课件.pptx
- 2025年新人教版一年级上册数学教学课件 2.2.5 8和9的加、减法.pptx
- 2025年新人教版数学一年级上册 第1单元 5以内数的认识和加、减法 1 1~5的认识 第2课时 比大小.pptx
- 2025年学期新人教版数学一年级上册课件 第2单元 6~10的认识和家、减法 3 10的认识和加、减法 第5课时 加、减混合.pptx
- 2025年学期新冀教版物理八年级上册课件 第三章 代数式 3.2.1 代数式.pptx
- 新苏教版(2022新课标)一年级上册数学课件 一 0~5的认识和加减法 练习二.pptx
- 鲁科版高中物理选择性必修第3册全册教学课件.pptx
- 2025年学期新北师大版数学七年级上册课件 第一章 丰富的图形世界 1.1 生活中的立体图形 1.1 生活中的立体图形(第2课时).pptx
- 2025年学期新教科版八年级上册物理课件 第2章 运动与能量 2 运动的描述.pptx
- 2025年新苏教版一年级上册数学课件 一 0~5的认识和加减法 练习二.pptx
最近下载
- 内江师范学院2021-2022学年第2学期《高等数学(下)》期末试卷(A卷)附标准答案.pdf
- 高思奥数一年级下册含答案第16讲 有趣的拆数.docx VIP
- 叉车安全考试题库及答案.doc VIP
- 新疆2024年高中学业水平考试化学试卷试题真题(含答案详解).docx VIP
- 卓长仁劫机案.doc VIP
- 国家建筑标准设计图集 23S519小型排水构筑物图集.pdf VIP
- 四年级语文下册期末试卷(人教版).doc VIP
- 金属塑性成形原理知到智慧树期末考试答案题库2024年秋山东建筑大学.docx VIP
- 《高效工作计划与目标管理培训课件》.ppt VIP
- 常见肿瘤标志物及临床意义.pptx VIP
文档评论(0)