模拟内存动态分配文档.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
模拟内存动态分配文档

模拟内存动态分配程序文件 一、功能概述 本程序是在VC++开发环境中编写的程序,采用了首次适应算法,并利用30*10的小圆圈形象地模拟出内存动态分配管理。 实现功能有:内存的分配、内存的回收、内存的显示及退出系统。 二、使用方法 1、打开可执行文件“模拟内存动态分配.exe”; 2、分配一块内存,输入1,再输入0~99之间的数作为进程号,和分配的内存大小; 如输入1,在输入2和23,可以显示已分配内存大小(实心圆显示)、和空闲区内存大小(空心圆表示),和空闲区起始地址和空闲区大小的队列。 3、回收已分配的内存,输入2,和进程号(由上图,输入2) 4、显示当前内存状态,输入3; 5、退出系统 三、一些异常情况的处理方法 1、进程号超出范围,提示输入错误 2、空闲区输入超出范围,未找到足够大的范围,要求重新输入; 3、分配输入进程号出现重复,要求进程号唯一; 四、一些关键源代码的说明 1、void swap(int i ,int j,int sign)//更新空闲区和非空闲区个数时,更新数组下标和计数器 { if (sign == 0) { empty temp; temp = Empty[i]; Empty[i] = Empty[j]; Empty[j] = temp; } else { not_empty temp; temp = Not_Empty[i]; Not_Empty[i] =Not_Empty[j]; Not_Empty[j] = temp; } } void decrease_CountOfEmpty()//更改后,重新统计空闲区个数 { int i; for (i=0;iCountOfEmpty;i++) { if (Empty[i].yesorno == 0) { swap(i,CountOfEmpty-1,0); CountOfEmpty -= 1; break; } } } void decrease_CountOfNotEmpty()//更改后,重新统计非空闲区个数 { int i; for (i=0;iCountOfNotEmpty;i++) { if (Not_Empty[i].yesorno == 0) { swap(i,CountOfNotEmpty-1,1); CountOfNotEmpty -= 1; break; } } } 说明: Swap函数实现对空闲区和已分配区下标的更新;decrease_CountOfEmpty()函数实现空闲区个数的更新,并帮助实现更新空闲区起始地址和大小队列;decrease_CountOfNotEmpty()函数实现非空闲区个数的更新。 2、int huishou() { int pid,i,a,b; cout输入要回收的进程号endl; cinpid; for (i=0;iCountOfNotEmpty;i++) { if (Not_Empty[i].pid == pid) { if (front(i,a) == 0) //待回收分区前面是空闲分区 { Empty[a].size_of_empty += Not_Empty[i].size_of_notempty; Not_Empty[i].yesorno = 0; if (back(i,b) == 0) //待回收区后面是空闲分区 { Empty[a].size_of_empty += Empty[b].size_of_empty; Empty[b].yesorno = 0; //空满空 回收之后 空 decrease_CountOfNotEmpty(); decrease_CountOfEmpty(); } else //待回收分区后面没分区,或后面是已分配分区 { //空满 回收之后 空 //空满满 回收之后 空满 decrease_CountOfNotEmpty(); } } else //待回收分区前面没分区,或前面是已分配分区 { if (back(i,b) == 0) //待回收区后面是空闲分区 { Empty[b].address_of_start = Not_Empty[i].address_of_start; Empty[b].size_of_empty += Not_Empty[i].size_o

文档评论(0)

2017ll + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档