操作系统存储管理实验报告
printf("请按任意键继续:\n");
getchar();
printf("每个分区装入一道作业:\n");
for(i=0;i<NUM;i++){
AllocateMemory((i+1)*3);
/
}
checkTab();
printf("请按任意键继续:\n");
getchar();
printf("假如一段时间后,其中一个作业结束,回收给它分配的分区(假如该作业在第2分区)\n");
printf("%c\t",parTab[i].state);
printf("\n");
}
}
void recycleMemory(int i)
{
]
parTab[i-1].state='N';
}
int main(int argc, char* argv[])
{
int i;
printf("\n\n\t\t*********************************************\t\t\n");
s++;
if(s>=n)
]
{
printf("找不到该作业\n");
return;
}
used_table[s].flag=0;
S=used_table[s].address;
L=used_table[s].length;
j=-1;
[
k=-1;
i=0;
while(i<m&&(j==-1||k==-1))
通过编写和调试地址转换过程的模拟程序以加强对地址转换过程的了解。
2、实验要求
#
设计一个固定式分区分配的存储管理方案,并模拟实现分区的分配和回收过程。
可以假定每个作业都是批处理作业,并且不允许动态申请内存。为实现分区的分配和回收,可以设定一个分区说明表,按照表中的有关信息进行分配,并根据分区的分配和回收情况修改该表。
free_table[t].length=L;
free_table[t].flag=1;
【
}
return;
}/*主存回收函数结束*/
int main( )
{
printf("\n\n\t\t*********************************************\t\t\n");
printf("\t\t\t\t实验三 存储管理实验\n");
t=0;
while(free_table[t].flag==1&&t<m)
t++;
if(t>=m) /*空闲区表满,回收空间失败,将已分配表复原*/
。
{
printf("主存空闲表没有空间,回收空间失败\n");
used_table[s].flag=J;
return;
}
free_table[t].address=S;
else
printf("没有空闲分区,无法分配内存!\n");
}
}
void createTab()
{
—
int i;
for( i=1;i<=NUM;i++)
{
o=i;
parTab[i-1].size=20;
parTab[i-1].firstAddr=21;
parTab[i-1].state='N';
}
ad=free_table[k].address;
xk=free_table[k].length;
}
else{
free_table[k].length=free_table[k].length-xk;
》
ad=free_table[k].address+free_table[k].length;
}
i=0;
return;
}
}
$
else
{
used_table[i].address=ad;
used_table[i].length=xk;
used_table[i].flag=J;
}
return;
}
(
void reclaim(char J)
{
int i,k,j,s,t;
float S,L;
s=0;
while((used_table[s].flag!=J||used_table[s].flag==0)&&s<n)
设计一个可变式分区分配的存储管理方案,并模拟实现分区的分配和回收过程。
对分区的管理法可以是下面三种算法之一:首次适应算法;最坏适应算法;最佳适应算法。
编写并调试一个段页式存储管理的地址转换的模拟程序。
首先设计好段表、页表,然后给出若干个有一定代表性的地址,通过查找段表页表后得到转换的地址。要求打印转换前的地址,相应的段表,页表条款及转换后的地址,以便检查。
free_table[0].length=10240; /*长度假定为10240,即10k*/
free_table[0].flag=1; /*初始空闲区为一个整体空闲区*/
\
for(i=1; i<m; i++)
free_table[i].flag=0; /*其余空闲分区表项未被使用*/
/*已分配表初始化:*/
printf("%%%6d\n",free_table[i].address,free_table[i].length, free_table[i].flag);
printf(" 按任意键,输出已分配区表\n");
getch();
printf(" 输出已分配区表:\n起始地址 分区长度 标志\n");
printf("\t\t\t\t实验一 存储管理实验\n");
printf("\t\t\t\t固定式分区分配存储管理\n");
>
printf("\t\t*********************************************\t\t\n");
createTab();
checkTab();
…
for(i=0; i<n; i++)
if(used_table[i].flag!=0)
printf("%%%6c\n",used_table[i].address,used_table[i].length, used_table[i].flag);
else
printf("%%%6d\n",used_table[i].address,used_table[i].length, used_table[i].flag);
recycleMemory(2);
checkTab();
printf("请按任意键继续:\n");
…
getchar();
printf("接着,从外存后备作业队列中选择一个作业装入该分区(假如该作业大小为10)\n");
AllocateMemory(10);
checkTab();
return 0;
}
#include<>
3、实验步骤
(1)理解实验要求,联系所学知识; (2)根据要求编写调度算法; (3)编写完整的实验代码并在VC++ 环境下编译运行; (4)调试程序直至得出结果。
4、
5、程序清单
#include <>
#include <>
#include<>
#include<>
#define NUM 4
#define alloMemory(type) (type*)malloc(sizeof(type))
;
}
void checkTab()
{
int i;
printf("分区号\t大小\t起址\t状态\n");
for(i=0;i<NUM;i++)
{
printf("%d\t",parTab[i].no);
`
printf("%d\t",parTab[i].size);
printf("%d\t",parTab[i].firstAddr);
if(k==-1||free_table[i].length<free_table[k].length)
k=i;
if(k==-1)
{
printf("无可用空闲区\n");
return;
}
-
if(free_table[k].length-xk<=minisize)
{
free_table[k].flag=0;
{
ifபைடு நூலகம்free_table[i].flag==1)
{
if(free_table[i].address+free_table[i].length==S)k=i;
if(free_table[i].address==S+L)j=i;
、
}
i++;
}
if(k!=-1)
if(j!=-1) /* 上邻空闲区,下邻空闲区,三项合并*/