ImageVerifierCode 换一换
格式:DOC , 页数:7 ,大小:56KB ,
资源ID:3045382      下载积分:20 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-3045382.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(实验 可变分区内存分配首次适应算法模拟.doc)为本站会员(11****ws)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

实验 可变分区内存分配首次适应算法模拟.doc

1、实验 可变分区内存分配首次适应算法模拟 一、 实验目的: 模拟内存分配 , 了解并掌握动态分区分配中所用的数据结构、分区分配算法 , 深刻理解首次适应内存分配算法 。 二、 实验内容: #include #include #include int const total= 200 ; /内存总数 int const beginaddress = 20;/初次分配起始地址 struct Block int addr; /块的起始地址 int size; / 块的大小 int flag; /块的分配状态 1:代表已分配 0:代表未分配; block100; int count=0; /块的个数,初

2、值为 0,分配一个则加 1,减少一个则减 1 void display() /显示所有块的模块 int i; printf(“ 目前内存情况 n“); printf(“- n“); printf(“ 块号 起始地址 大小 分配状态 n“); for(i=1;i #include #include int const total= 200 ; /内存总数 int const beginaddress = 20;/初次分配起始地址 struct Block int addr; /块的起始地址 int size; / 块的大小 int flag; /块的分配状态 1:代表已分配 0:代表未分配; b

3、lock100; int count=0; /块的个数,初值为 0,分配一个则加 1,减少一个则减 1 void display() /显示所有块的模块 int i; printf(“ 目前内存情况 n“); printf(“- n“); printf(“ 块号 起始地址 大小 分配状态 n“); for(i=1;i20 scanf(“%d“, total1=size+total; count+; if (count=1) blockcount.addr=beginaddress ; else blockcount.addr=blockcount-1.addr+blockcount-1.siz

4、e; blockcount.size=size; blockcount.flag=1; i+; count+; blockcount.addr=blockcount-1.addr+blockcount-1.size; blockcount.flag=0; blockcount.size=total-blockcount.addr; void jinchengEnter() /自己编写,采用首次适应算法 void jinchengExit() /作业调出内存模块 int kuaihao; printf(“请输入要调出内存的块号 :“); scanf(“%d“, if(blockkuaihao.f

5、lag=0) printf(“该块内存是 空闲的 ,无需调出 n“); else / 将该块设为空闲,就是将该块的 flag 设为 0, /还考虑了该块的下一块如果是空闲的,则将这两块合并为一块,总块数减 1 /如果要考虑该块的前一块是空闲,则将这两块合并为一块,总块数减 1,如何改代码? blockkuaihao.flag=0; if(blockkuaihao+1.flag=0) blockkuaihao.size=blockkuaihao.size+blockkuaihao+1.size; for(int i=kuaihao+2;i=count;i+) blocki-1=blocki; b

6、lockcount.size=0; blockcount.flag=0; blockcount.addr=0; count-; if(blockkuaihao-1.flag=0) blockkuaihao.size=blockkuaihao.size+blockkuaihao-1.size; for( int i=kuaihao+2;i=count;i+) blocki+1=blocki-1; blockcount.size=0; blockcount.flag=0; blockcount.addr=0; count-; display(); void main() int flag=0,se

7、lect; jinchengFirstEnter(); display(); while(flag=0) printf(“ 请输入相应操作 n“); printf(“ 1. 进程进入内存 n“); printf(“ 2. 进程退出内存 n“); printf(“ 3. 显示当前状态 n“); printf(“ 4. 退出 “); printf(“n n 请选择 :“); scanf(“%d“, switch(select) case 1:jinchengEnter();break; case 2:jinchengExit();break; case 3:display(); break; case 4:flag=1;break; default: printf(“选择错误,请重新选择 “);

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。