可变分区存储管理方式的内存分配回收.docVIP

可变分区存储管理方式的内存分配回收.doc

  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文档。上传文档
查看更多
可变分区存储管理方式的内存分配回收

实验报告 操作系统 班级:XXXXXXXXXXXX 学号:XXXXXXXXXXXX 姓名:XXXXXX 日期:XXXX.XX.XX 版本历史 Revisions History 版 本 号 Version Number 修改项目 To modify the project 修订者 Redactor 日期 Date 目录 1 引言 4 1.1 实验目的 4 1.2 参考文档 4 2 可变分区存储管理 5 2.1 实验原理分析 5 2.2 设计思路 5 2.3 源程序 6 2.4 重要结构体说明 10 2.5 重要变量说明 10 2.6 结果 11 2.7 测试方法对结果的分析 11 2.8 接口 12 2.8.1 接口设计说明 12 2.9 任务设计 12 2.9.1 流程图 12 引言 实验目的发人员系统.3.1节 空闲存储区表作系统.3.2节 首次适应法(.分算法,.回法)变分区存储管理 验原分析 计思路 分配法: 用首适应法为作来分配大小为内存空间时,总从表的起端的低地址部分开始查找,当第一找到大于或等于申请大小的空闲区时,就按所需大小分配给作业。如分配后原空闲区还有剩余空,就修改原存储区表项的使它记录的头如作业所需空间正好等于该空闲区大小,那么该空闲区表的成为接下来要删除表中这个即将随后的各非零表项依次上移一个位置。收法: 某作业以前所分配到的内存时,就要将该内存区归还给系统,使其成为空闲区而可被其作来使用。收时如释放区与邻近的空闲区相衔接,要将它们合并成较大的空闲区,否则闲区将被分割得超来越小,最终导致能利用;另外,空闲区个数来越多,也会使空闲区登记表溢出。序 /* | 如不会使用文件输入/输出,也不会使用I/O转向做输入和输出结果文件, | 可以手再抄输出结果后后再输到文件中,实验报告的文字内容由自己掌握,能多能少。 */ #include stdio.h #include malloc.h /*表的定义*/ #define N 5 #define MEMSIZE 1000 typedef struct map { unsigned m_size; char *m_addr; }; struct map coremap[N]; /* coremap表的初始化程序*/ void initcoremap(char *addr, unsigned size) { unsigned i; printf(init coremap, first addr: %d\n, addr); coremap[0].m_size = size; coremap[0].m_addr = addr; for(i = 1; i N; i++) { coremap[i].m_size = 0; coremap[i].m_addr = 0; } } /* 输出表的内容*/ void printcoremap(void) { unsigned i; /* 打印coremap表中各项的m_size和m_addr */ for(i = 0; i N; i++) { printf(coremap[%d].m_addr=%d , i, coremap[i].m_addr); printf(coremap[%d].m_size=%d\n, i, coremap[i].m_size); } } /* 首次适应的分配函数*/ char *fmalloc(unsigned size) { register char *a; register struct map *bp; for (bp = coremap; bp-m_size; bp++) { if(bp-m_size = size) { a = bp-m_addr; bp-m_addr += size; /* 修改表项的首地址*/ if((bp-m_size -= size) == 0) /* 有正好大小的空闲区*/ do { bp++; (bp - 1)-m_addr = bp-m_addr; /*

文档评论(0)

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

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

1亿VIP精品文档

相关文档