操作系统实验一可变分区存储管理

操作系统实验一可变分区存储管理

ID:15295095

大小:45.50 KB

页数:7页

时间:2018-08-02

操作系统实验一可变分区存储管理_第1页
操作系统实验一可变分区存储管理_第2页
操作系统实验一可变分区存储管理_第3页
操作系统实验一可变分区存储管理_第4页
操作系统实验一可变分区存储管理_第5页
资源描述:

《操作系统实验一可变分区存储管理》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、操作系统:实验一可变分区存储管理/*如不会使用文件输入/输出,也不会使用I/O转向做输入和输出结果文件,可以手再抄输出结果后后再输到文件中,实验报告的文字内容由自己掌握,能多能少。*/#include#include/*表的定义*/#defineN5structmap{unsignedm_size;char*m_addr;};structmapcoremap[N];/*首次适应的分配函数*/char*fmalloc(unsignedsize){registercha

2、r*a;registerstructmap*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;}while((bp-1)->m_size=bp->m_size);return(a);}}return(0);}/*首次适应的释放函数*/ffree(unsignedsiz

3、e,char*aa){structmap*bp;char*a,*t;unsignedtt;a=aa;for(bp=coremap;bp->m_addr<=a&&bp->m_size!=0;bp++);if(bp>coremap&&(bp-1)->m_addr+(bp-1)->m_size==a){/*情况1,2*/(bp-1)->m_size+=size;/*情况1*/if(a+size==bp->m_addr){/*情况2*/(bp-1)->m_size+=bp->m_size;while(bp->m

4、_size){bp++;(bp-1)->m_addr=bp->m_addr;(bp-1)->m_size=bp->m_size;}}}else{if(a+size==bp->m_addr&&bp->m_size){/*情况3*/bp->m_addr-=size;bp->m_size+=size;}else/*情况4*/if(size)do{t=bp->m_addr;bp->m_addr=a;a=t;tt=bp->m_size;bp->m_size=size;bp++;}while(size=tt);}}

5、/*coremap表的初始化程序*/voidinitcoremap(char*addr,unsignedsize){/*初始化coremap数组,使其第一项的m_addr指向用malloc申请到的addr,第一项的m_size等于malloc申请的size,其他各项清0*/}/*输出表的内容*/voidprintcoremap(){/*Functionbody:打印coremap表中各项的m_size和m_addr*/}/*主程序的框架*/main(){/*定义变量*//*用malloc向系统申请内存,

6、如1000*//*初始化coremap数组*//*命令处理部分,如msize:分配内存fsizeaddr:回收内存p:打印coremap表q:退出default:continue*//*调用free将用malloc申请到的内存释放*/}操作系统:实验一可变分区存储管理(答案)可变分区存储管理结构数组的形式:structmap{unsignedm_size;//空间大小char*m_addr;//起始地址};structmapcoremap[N];源程序和执行结果。#include#in

7、cludestructmap{unsignedm_size;char*m_addr;};structmapcoremap[1000];structmap*pp;voidprint_map();voidmain();char*lmalloc(structmap*mp,unsignedsize);voidlfree(unsignedsize,char*aa);structmapcoremap[1000];structmap*pp;char*lmalloc(structmap*mp,unsi

8、gnedsize)(registerinta;registerstructmap*bp;intpaddr=pp->m_addr;bp=pp;if(mp->m_size==0)return(0);if(!bp->m_size)bp=mp;do{if(bp->m_size>=size){a=bp->m_addr;bp->m_addr+=size;pp=bp;if((bp->m_size-=size)==0)do{bp++;(bp-1)->m_a

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。