实验三:存储管理

合集下载

实验三存储管理实验

实验三存储管理实验

实验三存储管理实验 Pleasure Group Office【T985AB-B866SYT-B182C-BS682T-STT18】实验三存储管理实验一. 目的要求:1、通过编写和调试存储管理的模拟程序以加深对存储管理方案的理解。

熟悉虚存管理的各种页面淘汰算法。

2、通过编写和调试地址转换过程的模拟程序以加强对地址转换过程的了解。

二.实验内容:1、设计一个固定式分区分配的存储管理方案,并模拟实现分区的分配和回收过程。

可以假定每个作业都是批处理作业,并且不允许动态申请内存。

为实现分区的分配和回收,可以设定一个分区说明表,按照表中的有关信息进行分配,并根据分区的分配和回收情况修改该表。

算法描述:本算法将内存的用户区分成大小相等的四个的分区,设一张分区说明表用来记录分区,其中分区的表项有分区的大小、起始地址和分区的状态,当系统为某个作业分配主存空间时,根据所需要的内存容量,在分区表中找到一个足够大的空闲分区分配给它,然后将此作业装入内存。

如果找不到足够大的空闲分区,则这个作业暂时无法分配内存空间,系统将调度另一个作业。

当一个作业运行结束时,系统将回收改作业所占据的分区并将该分区改为空闲。

算法原程序#include ""#include ""#include <>#include <>#define PCB_NUM 5 行程序.");printf("\n\t\t\t0.退出程序.");scanf("%d",&m);switch(m){case1:break;case0:system("cls");menu();break;default:system("cls");break;}}void paixu(struct MemInf* ComMem,int n){int i,j,t;for(j=0; j<n-1; j++)for(i=0; i<n-j-1; i++)if(ComMem[i].size>ComMem[i+1].size){t=ComMem[i].size;ComMem[i].size=ComMem[i+1].size;ComMem[i+1].size=t;}}void paixu2(){int i,j,t;for(j=0; j<4; j++)for(i=0; i<4-j; i++)if(pcbList[i].size>pcbList[i+1].size){t=pcbList[i].size;pcbList[i].size=pcbList[i+1].size; pcbList[i+1].size=t;}}void main(){DD:menu();char ch;int i,j,n,a=0;struct MemInf* ComMem;system("cls");printf("你要分多少个分区呢,请输入数值吧:");scanf("%d",&n);ComMem=(struct MemInf*)malloc(n*sizeof(struct MemInf));printf("请划分内存固定大小分区:\n");ize);if(i==0) ComMem[i].addr=40;ddr=ComMem[i-1].addr+ComMem[i-1].size;tate=0;ize+a;if(a>=INT){printf("超出规定内存范围");ch=getchar();ch=getchar();goto DD;}}paixu(ComMem,n);cbID =1;pcbList[0].RunState =0; ize=30;pcbList[0].RunTime =0;pcbList[0].TolTime =5;pcbList[1].pcbID =2;pcbList[1].RunState =0;pcbList[1].size=15;pcbList[1].RunTime =0;pcbList[1].TolTime =6;pcbList[2].pcbID =3;pcbList[2].RunState =0;pcbList[2].size=50;pcbList[2].RunTime =0;pcbList[2].TolTime =3;pcbList[3].pcbID =4;pcbList[3].RunState =0;pcbList[3].size=120;pcbList[3].RunTime =0;pcbList[3].TolTime =4;pcbList[4].pcbID =5;pcbList[4].RunState =0;pcbList[4].size=125;pcbList[4].RunTime =0;pcbList[4].TolTime =9;ch=getchar();ch=getchar();while(pcbList[PCB_NUM-1].RunTime < pcbList[PCB_NUM-1].TolTime){{for(j=0; j<PCB_NUM; j++){tate ==0&& pcbList[j].RunState==0) ize >= pcbList[j].size) tate =pcbList[j].pcbID ;pcbList[j].RunState=1;}}unTime >=pcbList[j].TolTime) tate == pcbList[j].pcbID){ComMem[i].state =0; unState=2; unState==1&& pcbList[i].RunTime < pcbList[i].TolTime) unTime++;cbID,pcbList[i].size, pcbList[i].RunState,pcbList[i].TolTime ,pcbList[i].RunTime);printf("分区ID\t 分区大小\t 状态\n");for(i=0; i<n; i++)printf("%d\t %d\t\t %d\n",i,ComMem[i].size ,ComMem[i].state );printf("按回车键继续...\n");getchar(); tart=-1;frees[i].length=0;strcpy(frees[i].tag,"free");occupys[i].start=-1;occupys[i].length=0;strcpy(occupys[i].tag,"");}free_quantity=0;occupy_quantity=0;}void writedata() tart);printf("输入第%d个分区的长度:\n",j);scanf("%d",&frees[i].length);}if((fp=fopen(fname,"wb"))==NULL)printf("错误,文件打不开,请检查文件名\n");for(i=0;i<SIZE;i++)if(fwrite(&frees[i],sizeof(struct node),1,fp)!=1)printf("文件写入错误!\n");fclose(fp);}void readdata() tart<=frees[t].start)t=j;}frees[free_quantity].start=frees[i].start;frees[free_quantity].length=frees[i].length;frees[i].start=frees[t].start;frees[i].length=frees[t].length;frees[t].start=frees[free_quantity].start;frees[t].length=frees[free_quantity].length;}}void view() tart,frees[i].length,frees[i].tag);printf("\n\n已分配分区表显示如下:\n");printf("起始地址\t长度\t占用作业名\n");for(j=0;j<occupy_quantity;j++)printf("%6dk\t%10dk\t%s\t\n",occupys[j].start,occupys[j].length,occupys[j].t ag);getchar();getchar();}void earliest() ength>=joblength)f=1;}if(f==0){printf("\n当前没有能满足你申请长度的空闲内存,请稍候再试\n");getchar();}else{ ength>=joblength){t=1;}j++;}j--;occupys[occupy_quantity].start=frees[j].start; ag,jobname); occupys[occupy_quantity].length=joblength;occupy_quantity++;if(frees[j].length>joblength){frees[j].start+=joblength;frees[j].length-=joblength;}else{for(i=j;i<free_quantity-1;i++){frees[i].start=frees[i+1].start;frees[i].length=frees[i+1].length;}free_quantity--;}printf("作业申请内存空间成功!\n");getchar();getchar();}}void excellent() ength>=joblength)f=1;}if(f==0){printf("\n当前没有能满足你申请长度的空闲内存,请稍候再试\n");getchar();}else ength>=joblength){t=1;}j++;}j--;for(i=0;i<free_quantity;i++){if(frees[i].length>=joblength&&frees[i].length<frees[j].length) j=i;}occupys[occupy_quantity].start=frees[j].start; ag,jobname);occupys[occupy_quantity].length=joblength;occupy_quantity++;if(frees[j].length>joblength){frees[j].start+=joblength;frees[j].length-=joblength;}else{for(i=j;i<free_quantity-1;i++){frees[i].start=frees[i+1].start;frees[i].length=frees[i+1].length;}free_quantity--;}printf("作业申请内存空间成功!\n");getchar();getchar();}}void worst(){char jobname[20];int joblength,f=0;int i,j;printf("请输入作业名:\n");scanf("%s",&jobname);printf("输入作业的长度:\n");scanf("%d",&joblength);for(i=0;i<free_quantity;i++){if(frees[i].length>=joblength)f=1;}if(f==0){printf("\n当前没有能满足你申请长度的空闲内存,请稍候再试\n");getchar();getchar();}else ength>=joblength){t=1;}j++;}j--;for(i=0;i<free_quantity;i++){if(frees[i].length>=joblength&&frees[i].length>frees[j].length) j=i;}occupys[occupy_quantity].start=frees[j].start; ag,jobname);occupys[occupy_quantity].length=joblength;occupy_quantity++;if(frees[j].length>joblength){frees[j].start+=joblength;frees[j].length-=joblength;}else{for(i=j;i<free_quantity-1;i++){frees[i].start=frees[i+1].start;frees[i].length=frees[i+1].length;}free_quantity--;}printf("作业申请内存空间成功!\n");getchar();getchar();}}void main(){initial();int n;writedata();system("cls");readdata();for(;;){sort();printf("************************************\n"); printf("************************************\n"); printf("** 欢迎使用可变分区存储管理系统 **\n");printf("************************************\n"); printf("** 1.显示空闲表和分配表 **\n");printf("** 2.首次适应算法 **\n");printf("** 3.最佳适应算法 **\n");printf("** 4.最坏适应算法 **\n");printf("** 0.退出系统 **\n"); printf("************************************\n"); printf("************************************\n"); printf("请输入您要选择的项目:\n");scanf("%d",&n);for(;;){if(n<0||n>4){printf("没有这个选项,请重新输入!");scanf("%d",&n);}elsebreak;}switch(n){case0:printf("感谢您的使用!再见!\n");exit(0);case1:view();break;case2:earliest();break;case3:excellent();break;case4:worst();break;}system("cls");}}测试结果:使用首次适应算法的结果:使用最佳适应算法:使用最坏适应算法:内存过满:3、编写并调试一个段页式存储管理的地址转换的模拟程序。

存储管理实验报告

存储管理实验报告

存储管理实验报告存储管理实验报告引言:存储管理是计算机系统中非常重要的一部分,它负责管理计算机系统中的存储资源,包括内存和外存。

合理的存储管理能够提高计算机系统的性能和效率,保证系统的稳定运行。

本次实验旨在通过实践操作,深入了解存储管理的原理和方法,并通过实验结果分析,探讨存储管理的优化策略。

一、实验目的本次实验的主要目的是通过实践操作,深入了解存储管理的原理和方法,并通过实验结果分析,探讨存储管理的优化策略。

具体目标如下:1. 了解存储管理的基本概念和原理;2. 掌握存储管理的常用方法和技术;3. 分析实验结果,探讨存储管理的优化策略。

二、实验环境本次实验使用了一台配置较高的计算机,具备较大的内存和高速的硬盘。

实验环境如下:1. 操作系统:Windows 10;2. 内存:16GB;3. 硬盘:1TB。

三、实验过程1. 内存管理实验在内存管理实验中,我们使用了一段较大的程序代码进行测试。

首先,我们通过编程语言将程序代码写入内存中,然后通过内存管理技术将程序代码加载到内存的合适位置。

在加载过程中,我们使用了分页和分段两种常用的内存管理技术,并比较了它们的性能差异。

实验结果显示,分页技术相对来说更加高效,能够更好地利用内存资源,提高系统的运行速度。

2. 外存管理实验在外存管理实验中,我们模拟了大文件的读写操作。

首先,我们将一个较大的文件写入硬盘中,然后通过外存管理技术将文件加载到内存中进行读取。

在加载过程中,我们使用了磁盘调度算法和文件系统管理技术,并比较了它们的性能差异。

实验结果显示,磁盘调度算法的选择对系统的读写速度有较大的影响,而文件系统的合理管理能够提高文件的存取效率。

四、实验结果分析通过对实验结果的分析,我们可以得出以下结论:1. 内存管理中,分页技术相对于分段技术更加高效,能够更好地利用内存资源,提高系统的运行速度;2. 外存管理中,磁盘调度算法的选择对系统的读写速度有较大的影响,合理选择磁盘调度算法能够提高系统的性能;3. 文件系统的合理管理能够提高文件的存取效率,减少文件的碎片化,提高系统的整体性能。

存储管理 实验报告

存储管理 实验报告

存储管理实验报告存储管理实验报告一、引言存储管理是计算机系统中一个非常重要的组成部分,它负责管理计算机内存的分配、回收和保护。

本次实验旨在通过实际操作,深入理解存储管理的原理和技术,并探索不同的存储管理策略对系统性能的影响。

二、实验目的1. 理解存储管理的基本概念和原理;2. 掌握常见的存储管理算法和策略;3. 分析不同存储管理策略对系统性能的影响。

三、实验环境本次实验使用了一台配置较低的个人电脑,操作系统为Windows 10,内存容量为4GB。

四、实验内容1. 静态分区分配算法静态分区分配算法是最简单的存储管理算法之一。

在实验中,我们使用了最先适应算法(First Fit)和最佳适应算法(Best Fit)进行静态分区分配。

通过对比两种算法的分配效果,我们发现最佳适应算法在减少内存碎片方面表现更好。

2. 动态分区分配算法动态分区分配算法是一种更加灵活的存储管理策略。

在实验中,我们实现了首次适应算法(First Fit)和最佳适应算法(Best Fit)两种动态分区分配算法。

通过观察不同算法的分配效果,我们发现首次适应算法在处理大量小内存块时效率较高,而最佳适应算法在处理大内存块时表现更好。

3. 页面置换算法页面置换算法是虚拟内存管理中的重要组成部分。

在实验中,我们实现了最近最少使用(LRU)算法和先进先出(FIFO)算法两种页面置换算法。

通过模拟内存不足的情况,我们观察了不同算法对系统性能的影响。

结果显示,LRU算法在减少页面置换次数方面比FIFO算法更为优秀。

五、实验结果与分析通过本次实验,我们对不同的存储管理算法和策略进行了实际操作,并观察了它们对系统性能的影响。

实验结果显示,最佳适应算法在静态分区分配中表现更好,而首次适应算法在动态分区分配中效率更高。

在页面置换算法中,LRU 算法在减少页面置换次数方面更为出色。

六、实验总结本次实验通过实际操作,深入理解了存储管理的原理和技术,并探索了不同的存储管理策略对系统性能的影响。

(完整word版)Linux操作系统实验报告 存储管理试验

(完整word版)Linux操作系统实验报告 存储管理试验
(2)利用随机函数动态生成进程访问页面的序列号。
(3)实现FIFO页面淘汰算法。
(4)实现页故障率反馈模型。
2、实验目的与要求
①(1)用C语言是实现模拟Linux系统中连续内存分配用到的伙伴对算法。
(2)通过链表的形式输出在内存申请和释放过程中内存状态的对比图。
②(1)了解工作集模型的原理及其特点。
printmem();
}
int power(int x,int y){
int k=0,tmp=1;
for(;k<y;k++){
tmp=tmp*x;
}
return tmp;
}
int root(int x,int y){
int result=y,count=0;
while(result!=1){
result=result/x;
merge(tempId,merger);
}else {
return 0;
}
return 1;
}else {
second=second->next;
isFirst++;
}
}
return 1;
}
int freeb(int size){
block * first=(struct block *)malloc(sizeof(struct block));
if((second->start==nextStart || second->start==preStart) && second->loc==0){
merger->size=(first->size)+(second->size);

存储管理实验报告

存储管理实验报告
int num, num2; //要调度的作业数和要回收的区域数
int m=0;//已分配作业数
int flag;//分配成功标志
int isup,isdow n; //回收区域存在上邻和下邻的标志
int is=0;
struct jcb {
char n ame[10];
char state;
int ntime; //所需时间
给作业占用;另一部分又成为一个较小的空闲区,留在空闲区表中。 为了尽量减少由于
分割造成的空闲区,尽可能分配低地址部分的空闲区,而尽量保存高地址部分有较大的
连续空闲区域,以利于大型作业的装入。 为此,在空闲区说明表中,把每个空闲区按其 地址顺序从低到高登记, 即每个后继的空闲区其起始地址总是比前者大。为了方便查找
为了说明那些分区是空闲的,可以用来装入新作业,必须有一张空闲说明表
长度——指出从起始地址开始的一个连续空闲的长度。
状态一一有两种状态,一种是 “未分配”状态,指出对应的由起址指出的某个长度的 区域是空闲区;另一种是 “空表目”状态, 表示表中对应的登记项目是空白(无效) 可用来登记新的空闲区(例如,作业完成后,它所占的区域就成了空闲区,应找一个
{
JCB *first;
if(ready==NULL) ready=p;
else{
first=ready;
while(first->li nk!=NULL)
first=first->li nk;
first->li nk=p;
p->li nk=NULL;
}
}
void sort3()/*建立对已分配作业队列的排列函数,直接插在队列之尾*/
实验三、存储管理

操作系统实验-存储管理

操作系统实验-存储管理

实验三存储管理【实验目的和要求】1、请求页式存储管理中页面置换算法模拟设计。

2、了解虚拟存储技术的特点。

3、掌握请求页式存储管理的页面置换算法。

【实验原理】1、存储管理的主要功能之一是合理地分配空间。

2、请求页式管理是一种常用的虚拟存储管理技术。

3、命中率=1-(页面失效次数/页地址流长度)。

本实验页面失效次数为每次访问相应指令时,该指令所对应的页不在内存的次数。

【实验步骤】一、问题描述与分析1、通过随机数产生一个指令序列,共320条指令。

指令的地址按下述原则生成:(1)50%的指令是顺序执行的;(2)25%的指令是均匀分布在前地址部分;(3)25%的指令是均匀分布在后地址部分。

具体的实施方法是:(1)在[0,319]的指令地址之间随机选取一起点m;(2)顺序执行一条指令,即执行地址为m+l的指今;(3)在前地址[0,m+l]中随机选取一条指令并执行,该指令的地址为m’;(4)顺序执行一条指今,其地址为m’ +l;(5)在后地址[m’ +2,319]中随机选取一条指令并执行;(6)重复上述步骤(1)一(5),直到执行320次指令。

2、将指令序列变换成为页地址流(1)页面大小为1K;(2)用户内存容量为4页到32页;(3)用户虚存容量为32K。

在用户虚存中,按每K存放10条指令排列虚存地址,即320条指令在虚存中的存放方式为:第0条~第9条指令为第0页(对应虚存地址为[0,9]);第10条~第19条指令为第1页(对应虚存地址为[10, l9]);……第310条~第319条指令为第31页(对应虚存地址为[310,3191]);按以上方式,用户指令可组成32页。

3、考虑计算并输出下述各种算法在不同内存容量下的命中率。

(1)先进先出的算法(FIFO) ;(2)最近最少使用算法(LRU);其中(1)和(2)必做三、程序设计与调试在VC++6.0环境下进行程序设计和调试。

程序分析:问题1:怎样使模拟的指令随机?答:通过使用C++的rand函数生成随机数,来产生指令,并用算法保证指定指令序列的需求。

存储管理实验报告

存储管理实验报告

存储管理实验报告一、实验目的1.了解存储管理的概念及作用;2.掌握存储管理的基本操作和技术;3.熟悉常见的存储管理工具和方法;4.分析存储管理对系统性能的影响。

二、实验内容1.了解存储管理的基本概念:存储管理是指对计算机中的存储器进行有效管理和利用的一种技术手段。

主要包括内存管理和外存管理两个方面。

2.学习常见的存储管理工具和方法:(1)内存管理方案:连续内存管理、非连续内存管理和虚存管理;(2)外存管理方案:磁盘存储管理、文件系统管理和缓存管理等。

3.实际操作存储管理工具:(1)使用操作系统的内存管理工具,如Windows的任务管理器和Linux的top命令等,查看内存使用情况和进程占用的内存大小;(2)使用磁盘管理工具,如Windows的磁盘管理器和Linux的fdisk命令等,查看磁盘的分区情况和使用状况;(3)使用文件系统管理工具,如Windows的资源管理器和Linux的ls命令等,查看文件和目录的存储和管理状态。

4.分析存储管理对系统性能的影响:(1)使用性能监控工具,如Windows的性能监视器和Linux的sar 命令等,实时监测系统的内存、磁盘和文件系统等性能指标;(2)对比不同存储管理方案的优缺点,分析其对系统性能的影响;(3)根据实验结果提出优化存储管理的建议。

三、实验步骤1.阅读相关文献和资料,了解存储管理的基本概念和原理;2.使用操作系统的内存管理工具,查看当前系统内存的使用情况;3.使用操作系统的磁盘管理工具,查看当前系统磁盘的分区情况;4.使用操作系统的文件系统管理工具,查看当前系统文件和目录的存储和管理状态;5.使用性能监控工具,实时监测系统的内存、磁盘和文件系统等性能指标;6.根据实验结果,分析存储管理对系统性能的影响;7.结合实验结果,提出优化存储管理的建议。

四、实验结果1.使用内存管理工具查看系统内存使用情况,发现部分进程占用内存过高,导致系统运行缓慢;2.使用磁盘管理工具查看系统磁盘分区情况,发现磁盘分区不合理,造成磁盘空间利用率较低;3.使用文件系统管理工具查看文件和目录的存储和管理状态,发现有大量重复和冗余的文件,需要进行清理和整理;4.使用性能监控工具实时监测系统的性能指标,发现内存和磁盘的利用率较高,需要优化存储管理。

计算机操作系统实验三存储器管理

计算机操作系统实验三存储器管理

计算机操作系统实验三存储器管理引言存储器管理是计算机操作系统中非常重要的一部分。

它负责管理计算机中的存储器资源,以便有效地分配和管理内存。

在操作系统的设计和实现中,存储器管理的性能和效率对整个系统的稳定性和性能有着重要的影响。

本文档将介绍计算机操作系统实验三中的存储器管理的实验内容及相关的知识点。

我们将从内存分区管理、页式存储管理和段式存储管理三个方面进行讨论。

内存分区管理内存分区管理是一种常见的存储器管理方法,旨在将物理内存分成若干个不同大小的区域,以便为不同的进程分配内存。

在实验三中,我们将学习和实现两种内存分区管理算法:首次适应算法和最佳适应算法。

首次适应算法是一种简单直观的算法,它从内存的起始位置开始查找第一个满足要求的空闲分区。

而最佳适应算法则是通过遍历整个内存空间,选择最合适的空闲分区来满足进程的内存需求。

通过实验,我们将学习如何实现这两种算法,并通过比较它们的性能和效果来深入理解内存分区管理的原理和实现。

页式存储管理页式存储管理是一种将物理内存分成固定大小的页框(page frame)和逻辑地址分成固定大小的页面(page)的管理方法。

在操作系统中,虚拟内存通过将进程的地址空间划分成大小相等的页面,并与物理内存中的页框相对应,实现了大容量的存储管理和地址空间共享。

在实验三中,我们将学习和实现页式存储管理的基本原理和算法。

我们将了解页表的结构和作用,以及如何通过页表将逻辑地址转换为物理地址。

此外,我们还将学习页面置换算法,用于处理内存不足时的页面置换问题。

段式存储管理段式存储管理是一种将逻辑地址分成不同大小的段并与物理内存中的段相对应的管理方法。

在操作系统的设计中,段式存储管理可以提供更灵活的地址空间管理和内存分配。

实验三将介绍段式存储管理的基本原理和实现方法。

我们将学习段表的结构和作用,以及如何通过段表将逻辑地址转换为物理地址。

同时,我们还将探讨段的分配和释放过程,并学习如何处理外部碎片的问题。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验三:存储管理 IMB standardization office【IMB 5AB- IMBK 08- IMB 2C】一、实验名称实验三:存储管理[1]Windows Server 2003内存结构[2] Windows Server 2003虚拟内存二、 [1]实验目的1)通过实验了解windows Server 2003内存的使用,学习如何在应用程序中管理内存、体会Windows应用程序内存的简单性和自我防护能力。

2)了解windows Server 2003的内存结构和虚拟内存的管理,进而了解进程堆和windows为使用内存而提供的一些扩展功能。

三、 [1]实验内容四、 [1]实验步骤Windows提供了一个API即GetSystemInfo() ,以便用户能检查系统中虚拟内存的一些特性。

程序5-1显示了如何调用该函数以及显示系统中当前内存的参数。

步骤1:登录进入Windows Server 2003 。

步骤2:在“开始”菜单中单击“程序”-“Microsoft Visual Studio 6.0”–“Microsoft Visual C++ 6.0”命令,进入Visual C++窗口。

步骤3:在工具栏单击“打开”按钮,在“打开”对话框中找到并打开实验源程序。

程序5-1:获取有关系统的内存设置的信息步骤4:单击“Build”菜单中的“Compile ”命令,并单击“是”按钮确认。

系统对进行编译。

步骤5:编译完成后,单击“Build”菜单中的“Build ”命令,建立可执行文件。

操作能否正常进行如果不行,则可能的原因是什么答:操作能正常进行。

_____________________________________________________ 步骤6:在工具栏单击“Execute Program” (执行程序) 按钮,执行程序。

运行结果 (分行书写。

如果运行不成功,则可能的原因是什么?) :1) 虚拟内存每页容量为:2) 最小应用地址: 0x000100003) 最大应用地址为: 0x7ffeffff4) 当前可供应用程序使用的内存空间为:5) 当前计算机的实际内存大小为:阅读和分析程序5-1,请回答问题:1)理论上每个windows应用程序可以独占的最大存储空间是:____4GB____2)在程序5-1中,用于检索系统中虚拟内存特性的API函数是: DWORD 提示:可供应用程序使用的内存空间实际上已经减去了开头与结尾两个64KB的保护区。

虚拟内存空间中的64KB保护区是防止编程错误的一种Windows方式。

任何对内存中这一区域的访问 (读、写、执行) 都将引发一个错误陷井,从而导致错误并终止程序的执行。

也就是说,假如用户有一个NULL指针 (地址为0) ,但仍试图在此之前很近的地址处使用另一个指针,这将因为试图从更低的保留区域读写数据,从而产生意外错误并终止程序的执行。

五、 [1]实验结论通过本次实验我了解windows Server 2003内存的使用,同时学习了如何在应用程序中管理内存。

在实验的过程中,体会到了Windows应用程序内存的简单性和自我防护能力。

对于Windows sever 2003的内存结构有了一定的了解。

二、[2]实验目的1)通过实验了解Windows Server 2003内存的使用,学习如何在应用程序中管理内存,体会Windows应用程序内存的简单性和自我防护能力。

2)学习检查虚拟内存空间或对其进行操作。

3)了解Windows Server 2003的内存结构和虚拟内存的管理,进而了解进程堆和Windows为使用内存而提供的一些扩展功能。

三、[2]实验内容与实验步骤1. 虚拟内存的检测清单5-2所示的程序使用VirtualQueryEX()函数来检查虚拟内存空间。

步骤1:登录进入Windows Server 2003。

步骤2:在“开始”菜单中单击“程序”-“Microsoft Visual Studio 6.0”–“Microsoft Visual C++ 6.0”命令,进入Visual C++窗口。

步骤3:在工具栏单击“打开”按钮,在“打开”对话框中找到并打开实验源程序。

清单5-2 检测进程的虚拟地址空间清单5-2中显示一个walkVM()函数开始于某个进程可访问的最低端虚拟地址处,并在其中显示各块虚拟内存的特性。

虚拟内存中的块由VirsualQueryEX()API定义成连续快或具有相同状态(自由区,已调配区等)的内存,并分配以一组统一的保护标志(只读、可执行等)。

步骤4:单击“Build”菜单中的“Compile ”命令,并单击“是”按钮确认。

系统对进行编译。

步骤5:编译完成后,单击“Build”菜单中的“Build ”命令,建立可执行文件。

操作能否正常进行如果不行,则可能的原因是什么答:操作能正常运行。

___________________________________________________ 步骤6:在工具栏单击“Execute Program” (执行程序) 按钮,执行程序。

1)分析运行结果(如果运行不成功,则可能的原因是什么)按committed,reserved,free等三种虚拟地址空间分别记录实验数据,其中“描述”是对该组数据的简单描述,例如,对下列一组数据:可描述为:具有READWRITE权限的已调配私有内存区。

将系统当前的自由区(Free)虚拟地址空间填入表3-3中。

答:该程序从主函数Main()出发,调用void WalkVM(HANDLE hProcess)函数,void WalkVM(HANDLE hProcess)函数获得系统信息,分配应用程序内存地址空间。

然后开始做循环,从函数运行开始每次获得下一个虚拟程序内存块的信息,之后计算块的结尾及大小,然后再显示块的大小与位置,状态,显示保护方式(void ShowProtection(DWORD dwTarget)),将文件名显示出来,移动块指针获得下一块,依次这样循环下去,直至结束。

2. 虚拟内存的分配与释放能正确使用系统函数GetMeoryStatus()和数据结构MEMORY_STATUS了解系统内存和虚拟存储空间使用情况,会使用VirsualAlloc()函数和VirsualFree()函数分配和释放虚拟内存空间。

步骤1:在VC 环境下选择Win32 Console Application建立一个控制台工程文件,选择An application that Supports MFC。

步骤2:编辑并编译完成后,单击“Build”菜单中的“Build ”命令,建立可执行文件。

操作能否正常进行如果不行,则可能的原因是什么答:操作能正常进行。

______________________________________________________ 步骤3:在工具栏单击“Execute Program”按钮,执行程序。

分析程序的运行结果1) 请描述运行结果 (如果运行不成功,则可能的原因是什么?) :答:运行结果如下:Current Memory Status is :Total Physical Memory is 2047 MBAvailable Physical Memory is 2047 MBTotal Page File is 4095 MBAvailable Page File is 4095 MBTotal Virtual Memory is 2047 MBAvailable Virsual memory is 2031 MBMemory Load is 22 %Now Allocate 32M Virsual Memory and 2M Physical MemoryCurrent Memory Status is :Total Physical Memory is 2047 MBAvailable Physical Memory is 2047 MBTotal Page File is 4095 MBAvailable Page File is 4095 MBTotal Virtual Memory is 2047 MBAvailable Virsual memory is 1997 MBMemory Load is 22 %Now Release 32M Virsual Memory and 2M Physical MemoryCurrent Memory Status is :Total Physical Memory is 2047 MBAvailable Physical Memory is 2047 MBTotal Page File is 4095 MBAvailable Page File is 4095 MBTotal Virtual Memory is 2047 MBAvailable Virsual memory is 2031 MBMemory Load is 22 %Press any key to continue2) 根据运行输出结果,若要改变分配和回收的虚拟内存和物理内存的大小,要改变程序代码的语句,分别为:答:要改变的分配虚拟内存的程序代码语句为:if (BaseAddr==NULL) printf("Virsual Allocate Fail.\n");str=(char *)malloc(1024*1024*2);GetMemSta();要改变的回收虚拟内存的程序代码语句为:if (::VirtualFree(BaseAddr,0,MEM_RELEASE)==0)printf("Release Allocate Fail.\n");free(str);3) 根据运行输出结果,对照分析5-2程序,可以看出程序运行的流程吗?请简单描述:答:程序开始运行,分配虚拟内存为32M,物理内存为2M,后进行虚拟内存释放,释放了32M虚拟内存,2M物理内存。

四、 [2]实验结论通过本次实验了解windows Server 2003的内存结构和虚拟内存的管理,较为清楚的理解了在windows sever 2003中虚拟内存的检测以及其内存分配和内存释放的运行过程。

进而了解进程堆和windows为使用内存而提供的一些扩展功能。

在程序运行的过程中,首先会检测到需要使用的虚拟内存,其次通过调用函数去分配当前部分所需要的虚拟内存大小,之后进行虚拟内存的分配,最后,运行结束,释放虚拟内存。

在这整个过程中,能够节约内存的使用,增加了处理事务的效率。

相关文档
最新文档