存储管理实验报告

合集下载

存储器管理实验实验报告

存储器管理实验实验报告

存储器管理实验实验报告一、实验目的存储器管理是操作系统的重要组成部分,本次实验的目的在于深入理解存储器管理的基本原理和方法,通过实际操作和观察,掌握存储器分配与回收的算法,以及页面置换算法的实现和性能评估。

二、实验环境本次实验使用的操作系统为 Windows 10,编程语言为 C++,开发工具为 Visual Studio 2019。

三、实验内容与步骤(一)存储器分配与回收算法实现1、首次适应算法(1)原理:从空闲分区链的首地址开始查找,找到第一个满足需求的空闲分区进行分配。

(2)实现步骤:建立空闲分区链表,每个节点包含分区的起始地址、大小和状态(已分配或空闲)。

当有分配请求时,从链表头部开始遍历,找到第一个大小满足需求的空闲分区。

将该分区进行分割,一部分分配给请求,剩余部分仍作为空闲分区留在链表中。

若找不到满足需求的空闲分区,则返回分配失败。

2、最佳适应算法(1)原理:从空闲分区链中选择与需求大小最接近的空闲分区进行分配。

(2)实现步骤:建立空闲分区链表,每个节点包含分区的起始地址、大小和状态。

当有分配请求时,遍历整个链表,计算每个空闲分区与需求大小的差值。

选择差值最小的空闲分区进行分配,若有多个差值相同且最小的分区,选择其中起始地址最小的分区。

对选中的分区进行分割和处理,与首次适应算法类似。

3、最坏适应算法(1)原理:选择空闲分区链中最大的空闲分区进行分配。

(2)实现步骤:建立空闲分区链表,每个节点包含分区的起始地址、大小和状态。

当有分配请求时,遍历链表,找到最大的空闲分区。

对该分区进行分配和处理。

(二)页面置换算法实现1、先进先出(FIFO)页面置换算法(1)原理:选择在内存中驻留时间最久的页面进行置换。

(2)实现步骤:建立页面访问序列。

为每个页面设置一个进入内存的时间戳。

当发生缺页中断时,选择时间戳最早的页面进行置换。

2、最近最久未使用(LRU)页面置换算法(1)原理:选择最近一段时间内最长时间未被访问的页面进行置换。

存储管理实验报告

存储管理实验报告

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

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

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

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

具体目标如下: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 算法在减少页面置换次数方面更为出色。

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

存储管理实验报告

存储管理实验报告
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. 实验步骤本实验共分为以下几个步骤:步骤一:了解存储器管理的基本概念在开始实验之前,我们首先需要了解存储器管理的基本概念。

包括内存分区、内存分配算法、内存回收算法等。

步骤二:设计实验代码根据实验要求,我们需要编写代码来实现常见的存储器管理算法。

可以选择使用C、C++等编程语言来实现。

步骤三:实验代码测试完成代码编写后,我们需要对代码进行测试,以验证其正确性和可行性。

可以编写一些测试样例来测试不同的存储器管理算法。

步骤四:实验结果分析根据实验的结果,我们可以对不同的存储器管理算法进行比较和分析,评估其优劣和适用性。

步骤五:实验总结在实验结束后,我们可以对实验过程和结果进行总结,总结实验中所学到的知识和经验,并提出改进的建议。

4. 实验总结通过本次实验,我深入了解了存储器管理的基本概念和原理,并通过编写代码实现了常见的存储器管理算法。

实验过程中,我遇到了一些问题,但通过查阅相关文献和资料,最终解决了这些问题。

通过实验,我不仅加深了对存储器管理的理解,还提高了编程能力和问题解决能力。

5. 改进建议在实验过程中,我发现代码实现的效率还有待提高,可以进一步优化算法的设计和实现。

此外,可以扩展实验内容,研究更多的存储器管理算法,并进行比较和分析。

参考文献•[1] 《操作系统教程》•[2] 《计算机体系结构》•[3] 《操作系统原理》。

操作系统存储管理实验报告

操作系统存储管理实验报告

操作系统存储管理实验报告一、实验目的本次实验的目的是通过编写一段程序,实现对内存的分配和回收操作,并验证算法的正确性和性能。

二、实验内容1.实现首次适应算法首次适应算法是一种动态分配的内存管理算法,通过从低地址往高地址内存块,找到第一个满足需求的空闲块进行分配。

具体实现过程如下:(1)初始化内存空间,设置内存块的大小和地址范围;(2)编写一个函数,实现内存的分配操作,根据需求大小找到第一个合适的空闲块,并在其前后设置相应的标志位;(3)编写一个函数,实现内存的回收操作,根据释放块的地址,将其前后的标志位进行合并;(4)模拟应用程序的运行,测试内存的分配和回收操作。

2.实现最佳适应算法最佳适应算法是一种动态分配的内存管理算法,通过整个内存空间,找到最小的满足需求的空闲块进行分配。

具体实现过程如下:(1)初始化内存空间,设置内存块的大小和地址范围;(2)编写一个函数,实现内存的分配操作,遍历整个内存空间,找到满足需求且大小最小的空闲块进行分配;(3)编写一个函数,实现内存的回收操作,根据释放块的地址,将其前后的标志位进行合并;(4)模拟应用程序的运行,测试内存的分配和回收操作。

三、实验结果1.首次适应算法经过测试,首次适应算法能够正确地进行内存的分配和回收操作,并且算法的性能良好。

尽管首次适应算法在分配过程中可能会产生碎片,但是由于它从低地址开始,可以在较短的时间内找到满足需求的空闲块。

在实际应用中,首次适应算法被广泛采用。

2.最佳适应算法经过测试,最佳适应算法能够正确地进行内存的分配和回收操作,并且算法的性能较好。

最佳适应算法会整个内存空间,找到大小最小的满足需求的空闲块。

因此,在分配过程中不会产生很多的碎片,但是算法的执行时间较长。

四、实验总结通过本次实验,我们成功地实现了首次适应算法和最佳适应算法,并对算法的正确性和性能进行了验证。

两种算法在内存的分配和回收过程中都表现出良好的性能,可广泛应用于实际场景中。

操作系统存储管理实验报告总结

操作系统存储管理实验报告总结

操作系统存储管理实验报告总结篇一:东华大学操作系统存储管理实验报告东华大学计算机学院操作系统实验报告实验名称:存储管理问题姓名:姜元杰学号:111310228班级:计算机1102 指导老师:李继云报告日期: XX/11/2一、实验概述1. 实验目标存储管理的主要功能之一是合理地分配空间。

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

本实验的目的是通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特点,掌握请求页式管理的页面置换算法。

2. 实验要求1) 通过随机数产生一个指令序列,共320条指令,指令的地址按下述原则生成:? 50%的指令是顺序执行的;? 25%的指令是均匀分布在前地址部分。

? 25%的指令是均匀分布在后地址部分。

2) 将指令序列变换成页地址流? 页面大小 = 10条指令? 4页? 用户虚存容量 = 32页;? 在用户虚存中,按每K存放10条指令排列虚存地址3) 计算并输出下述各种算法在不同内存容量下的命中率。

? 先进先出的算法(FIFO);? 最近最少使用算法(LRU);? 最佳淘汰算法(OPT);? 命中率=1-页面失效次数/页地址流长度;输出以表结构输出,行头是页码,列头是对应替换算法。

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

二、实验内容1. 设计思路总体思路:设计存储管理类(class StorageManagemen),封装FIFO,LRU,OPT算法实现函数与各自所需公共或个体数据机构和公共代码部分,实现“TOP-DOWN”的程序设计思想,增强代码结构性和可读性。

1) 先进先出的算法(FIFO):FIFO是最简单的页置换算法,FIFO的页置换的算法为每个页记录着该页调入内存的时间。

当必须置换一页时,将选择最旧的页。

注意并不需要记录调入一页的确切时间,可以创建一个FIFO队列来管理内存中的所有页。

队列中的首页将被置换。

实验四 操作系统存储管理实验报告

实验四  操作系统存储管理实验报告

实验四操作系统存储管理实验报告一、实验目的本次操作系统存储管理实验的主要目的是深入理解操作系统中存储管理的基本原理和方法,通过实际操作和观察,掌握内存分配、回收、地址转换等关键技术,提高对操作系统存储管理机制的认识和应用能力。

二、实验环境操作系统:Windows 10开发工具:Visual Studio 2019三、实验原理1、内存分配方式连续分配:分为单一连续分配和分区式分配(固定分区和动态分区)。

离散分配:分页存储管理、分段存储管理、段页式存储管理。

2、内存回收算法首次适应算法:从内存低地址开始查找,找到第一个满足要求的空闲分区进行分配。

最佳适应算法:选择大小最接近作业需求的空闲分区进行分配。

最坏适应算法:选择最大的空闲分区进行分配。

3、地址转换逻辑地址到物理地址的转换:在分页存储管理中,通过页表实现;在分段存储管理中,通过段表实现。

四、实验内容及步骤1、连续内存分配实验设计一个简单的内存分配程序,模拟固定分区和动态分区两种分配方式。

输入作业的大小和请求分配的分区类型,程序输出分配的结果(成功或失败)以及分配后的内存状态。

2、内存回收实验在上述连续内存分配实验的基础上,添加内存回收功能。

输入要回收的作业号,程序执行回收操作,并输出回收后的内存状态。

3、离散内存分配实验实现分页存储管理的地址转换功能。

输入逻辑地址,程序计算并输出对应的物理地址。

4、存储管理算法比较实验分别使用首次适应算法、最佳适应算法和最坏适应算法进行内存分配和回收操作。

记录不同算法在不同作业序列下的内存利用率和分配时间,比较它们的性能。

五、实验结果与分析1、连续内存分配实验结果固定分区分配方式:在固定分区大小的情况下,对于作业大小小于或等于分区大小的请求能够成功分配,否则分配失败。

内存状态显示清晰,分区的使用和空闲情况一目了然。

动态分区分配方式:能够根据作业的大小动态地分配内存,但容易产生内存碎片。

2、内存回收实验结果成功回收指定作业占用的内存空间,内存状态得到及时更新,空闲分区得到合并,提高了内存的利用率。

存储管理实验报告

存储管理实验报告

存储管理实验报告一、实验目的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.使用性能监控工具实时监测系统的性能指标,发现内存和磁盘的利用率较高,需要优化存储管理。

操作系统存储管理实验报告

操作系统存储管理实验报告

操作系统存储管理实验报告一、实验目的操作系统的存储管理是计算机系统中非常重要的组成部分,它直接影响着系统的性能和资源利用率。

本次实验的目的在于深入理解操作系统中存储管理的基本原理和方法,通过实际操作和观察,掌握存储分配、回收、地址转换等关键技术,并对不同存储管理策略的性能进行分析和比较。

二、实验环境本次实验在 Windows 10 操作系统下进行,使用 Visual Studio 2019 作为编程环境,编程语言为 C++。

三、实验内容(一)固定分区存储管理1、原理固定分区存储管理将内存空间划分为若干个固定大小的分区,每个分区只能装入一道作业。

分区的大小可以相等,也可以不等。

2、实现创建一个固定大小的内存空间数组,模拟内存分区。

为每个分区设置状态标志(已分配或空闲),并实现作业的分配和回收算法。

3、实验结果与分析通过输入不同大小的作业请求,观察内存的分配和回收情况。

分析固定分区存储管理的优缺点,如内存利用率低、存在内部碎片等。

(二)可变分区存储管理1、原理可变分区存储管理根据作业的实际需求动态地划分内存空间,分区的大小和数量是可变的。

2、实现使用链表或数组来管理内存空间,记录每个分区的起始地址、大小和状态。

实现首次适应、最佳适应和最坏适应等分配算法,以及分区的合并和回收算法。

3、实验结果与分析比较不同分配算法的性能,如分配时间、内存利用率等。

观察内存碎片的产生和处理情况,分析可变分区存储管理的优缺点。

(三)页式存储管理1、原理页式存储管理将内存空间和作业都划分为固定大小的页,通过页表将逻辑地址转换为物理地址。

2、实现设计页表结构,实现逻辑地址到物理地址的转换算法。

模拟页面的调入和调出过程,处理缺页中断。

3、实验结果与分析测量页式存储管理的页面置换算法(如先进先出、最近最少使用等)的命中率,分析其对系统性能的影响。

探讨页大小的选择对存储管理的影响。

(四)段式存储管理1、原理段式存储管理将作业按照逻辑结构划分为若干个段,每个段有自己的名字和长度。

存储管理实验报告_6

存储管理实验报告_6

昆明理工大学信息工程与自动化学院学生实验报告(2012 —2013 学年第二学期)一、实验目的存储管理的主要功能之一是合理地分配空间。

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

通过本次实验, 要求学生通过编写和调试地址转换过程的模拟程序以加强对地址转换过程的了解, 通过请求页式存储管理中页面置换算法模拟设计, 了解虚拟存储技术的特点, 掌握请求页式存储管理的页面置换算法。

二、实验原理及基本技术路线图(方框原理图)用C或C++语言模拟实现请求式分页管理。

要求实现: 页表的数据结构、分页式内存空间的分配及回收(建议采用位图法)、地址重定位、页面置换算法(从FIFO,LRU,NRU中任选一种)。

int subareaSize[num]={8,12,16,32,24,16,64,128,40,64};//分区大小Process *pro=NULL;//保持进程信息int ProcessNum=0;//进程数目int applyProcessNum=0;//每次申请进程数目int maxApplyNum=0;//最大可申请数目int *applyIndex=NULL;//申请进程队列int totalApplyNum=0;//申请总数int *assignPointer=NULL;//已分配内存的进程队列int assignFlag=0;//分配索引, 表示已申请队列已分配的进程数int exeIndex;//执行的进程号Node *subareaNode=new Node[3];//分区回收时, 进程所在分区及其前, 后分区信息LinkList createLinkList(int n );//建立空闲分区链Node firstFit(LinkList &head,Process pro);//首次适应算法Node nestFit(LinkList &head,Process pro,Node flag);//循环适应算法Node bestFit(LinkList &head,Process pro);//最佳适应算法Node worstFit(LinkList &head,Process pro);//最坏适应算法Node assign(LinkList &head,int orderIndex,int index,Node flagNode);//一次分区分配int assignMemory(LinkList &head);//内存分配void insertNode(LinkList &head,Node q,int index);//插入节点Node deleteNode(LinkList &head,int index);//删除节点int display(LinkList &head);//打印分区分配情况int lowAttemper(int *excursionPointer);//低级调度int findSubarea(LinkList &head,int index);//回收内存int creatProcess();//创建进程Process* randomCreatPro(int n);//随机产生进程下面是各种方法简述:(1) 最优替换算法, 即OPT算法。

实验四操作系统存储管理实验报告

实验四操作系统存储管理实验报告

实验四操作系统存储管理实验报告一、实验目的本次实验的主要目的是深入理解操作系统中存储管理的基本原理和方法,通过实际操作和观察,掌握内存分配与回收、页面置换算法等关键概念,并能够分析和解决存储管理中可能出现的问题。

二、实验环境本次实验在装有 Windows 操作系统的计算机上进行,使用了 Visual Studio 等编程工具和相关的调试环境。

三、实验内容(一)内存分配与回收算法实现1、首次适应算法首次适应算法从内存的起始位置开始查找,找到第一个能够满足需求的空闲分区进行分配。

在实现过程中,我们通过建立一个空闲分区链表来管理内存空间,每次分配时从表头开始查找。

2、最佳适应算法最佳适应算法会选择能够满足需求且大小最小的空闲分区进行分配。

为了实现该算法,在空闲分区链表中,分区按照大小从小到大的顺序排列,这样在查找时能够快速找到最合适的分区。

3、最坏适应算法最坏适应算法则选择最大的空闲分区进行分配。

同样通过对空闲分区链表的排序和查找来实现。

(二)页面置换算法模拟1、先进先出(FIFO)页面置换算法FIFO 算法按照页面进入内存的先后顺序进行置换,即先进入内存的页面先被置换出去。

在模拟过程中,使用一个队列来记录页面的进入顺序。

2、最近最久未使用(LRU)页面置换算法LRU 算法根据页面最近被使用的时间来决定置换顺序,最近最久未使用的页面将被置换。

通过为每个页面设置一个时间戳来记录其最近使用的时间,从而实现置换策略。

3、时钟(Clock)页面置换算法Clock 算法使用一个环形链表来模拟内存中的页面,通过指针的移动和页面的访问标志来决定置换页面。

四、实验步骤(一)内存分配与回收算法的实现步骤1、初始化内存空间,创建空闲分区链表,并为每个分区设置起始地址、大小和状态等信息。

2、对于首次适应算法,从链表表头开始遍历,找到第一个大小满足需求的空闲分区,进行分配,并修改分区的状态和大小。

3、对于最佳适应算法,在遍历链表时,选择大小最接近需求的空闲分区进行分配,并对链表进行相应的调整。

《操作系统》存储管理实验报告

《操作系统》存储管理实验报告

《操作系统》存储管理实验报告操作系统是计算机系统中最基础、最核心的软件之一,负责管理计算机硬件资源和提供资源的分配与调度。

而存储管理是操作系统中的重要组成部分,它负责管理计算机的内存,包括内存的分配、回收、保护等操作。

本文将针对存储管理进行实验,并撰写实验报告。

本次实验主要涉及以下内容:内存的分配与回收、内存的保护。

实验过程中,我首先根据操作系统的要求,设计了相应的算法用于内存的分配与回收。

并通过编写程序,验证了算法的正确性。

随后,我进一步研究了内存的保护机制,通过设置访问权限位和访问控制表,实现了对内存的合理保护。

在内存的分配与回收方面,我设计了一种简单的算法,首次适应算法。

具体实现如下:首先,将内存分为若干个块,每个块的大小为固定值。

当需要分配内存时,首先遍历内存块列表,找到第一个大小合适的块,将其分配给进程。

当进程终止时,将其占用的内存块回收,以便后续进程使用。

通过编写程序进行测试,结果表明该算法能够正确地进行内存的分配与回收。

在内存的保护方面,我采用了访问权限位和访问控制表的方式进行。

具体实现如下:首先,为每个进程分配一组访问权限位,记录了该进程能够访问的内存区域。

同时,设置一个访问控制表,记录了每个内存块的权限。

当进程访问一些内存块时,首先检查该进程的访问权限位,再与访问控制表中的权限进行比较,以确定该进程是否有权限访问该内存块。

通过编写程序进行测试,证明了该机制能够有效地保护内存。

总结来说,本次实验主要涉及了操作系统中的存储管理部分,包括内存的分配与回收、内存的保护。

通过设计算法和编写程序,我成功地实现了这些功能,并验证了其正确性。

通过本次实验,我进一步加深了对操作系统存储管理的理解,提高了编程和设计的能力。

存储管理实验报告总结

存储管理实验报告总结

存储管理实验报告总结本次实验主要是针对存储管理进行的。

存储管理是操作系统中非常重要的一部分,它负责管理计算机系统的内存空间,为进程提供必要的存储资源。

通过本次实验,我对存储管理的相关概念和技术有了更加深入的了解。

在实验中,我首先学习了存储管理的基本原理。

操作系统将内存分为若干个大小相等的页框,而进程的内存空间则被划分为若干个大小相等的页。

通过页表的映射关系,操作系统可以将进程的页映射到物理内存的页框上。

这样,进程就可以方便地访问内存中的数据。

在实验中,我还学习了虚拟内存的概念和实现方法。

虚拟内存是一种扩展内存的方法,它允许进程访问超出物理内存容量的数据。

虚拟内存通过将进程的页映射到磁盘上的页面文件中,实现了内存的扩展。

当进程需要访问某个页面时,操作系统会将该页面从页面文件中加载到物理内存中,并更新页表的映射关系。

在实验中,我还学习了页面置换算法的原理和实现。

页面置换算法是虚拟内存中非常重要的一部分,它负责决定哪些页面需要被置换出去。

常见的页面置换算法有FIFO算法、LRU算法和Clock算法等。

不同的算法有着不同的性能特点和适用场景,我们需要根据具体的应用场景选择合适的页面置换算法。

在实验中,我还学习了内存分配和回收的方法。

操作系统通过内存分配算法为进程分配内存空间,而通过内存回收算法回收进程不再使用的内存空间。

内存分配算法的选择会影响到系统的性能和资源利用率,我们需要根据具体的应用场景选择合适的内存分配算法。

通过本次实验,我深入了解了存储管理的相关概念和技术。

存储管理是操作系统中非常重要的一部分,它直接影响到系统的性能和资源利用率。

合理地管理存储资源可以提高系统的运行效率和稳定性,从而提升用户的体验。

在今后的学习和工作中,我将进一步深化对存储管理的理解,不断提升自己的技术水平。

分区存储管理实验报告

分区存储管理实验报告

分区存储管理实验报告分区存储管理实验报告一、引言分区存储管理是计算机操作系统中的重要概念之一,它的目的是将计算机的内存划分为若干个不同的区域,以便更有效地管理和利用内存资源。

本实验旨在通过实际操作,深入理解分区存储管理的原理和实现方式。

二、实验目的1. 掌握分区存储管理的基本原理;2. 熟悉分区存储管理的实现方式;3. 了解分区存储管理的优缺点。

三、实验方法本实验采用了虚拟机技术,在虚拟机上搭建了一个简单的操作系统环境。

通过操作系统提供的命令和工具,对内存进行分区存储管理的相关操作和观察。

四、实验过程1. 创建分区在操作系统中,我们可以使用命令或工具来创建分区。

通过指定分区的大小和位置,将内存划分为不同的区域。

这些区域可以用来存储不同的程序和数据。

2. 分配内存一旦分区创建完成,我们可以使用操作系统提供的命令或API来分配内存。

分配内存时,需要指定所需内存的大小和分区的位置。

操作系统会检查分区的空闲情况,并将所需内存分配给请求的进程。

3. 回收内存当进程不再使用分配给它的内存时,操作系统可以回收这部分内存,并将其标记为空闲状态。

这样,其他进程可以再次申请并使用这部分内存。

4. 碎片整理在长时间运行的系统中,由于内存的分配和回收,可能会产生内存碎片。

内存碎片是指内存中存在的一些不连续且无法利用的小块空闲内存。

为了更有效地利用内存资源,操作系统可以定期进行碎片整理,将相邻的小块空闲内存合并成较大的连续空闲内存。

五、实验结果通过实验,我们成功地创建了多个分区,并成功地分配了内存给不同的进程。

我们观察到,在内存分配过程中,操作系统会根据分区的空闲情况选择最合适的分区进行分配。

同时,我们还发现了内存碎片的存在,并通过碎片整理操作将碎片合并成更大的连续空闲内存。

六、实验总结分区存储管理是一种有效的内存管理方式,它可以提高内存的利用率,减少内存碎片的产生。

然而,分区存储管理也存在一些缺点。

例如,分区的大小和数量需要提前规划,不够灵活。

存储器管理实验报告

存储器管理实验报告

存储器管理实验报告存储器管理实验报告一、引言存储器管理是计算机操作系统中至关重要的一部分,它负责管理计算机的内存资源。

在本次实验中,我们将通过模拟实验来深入了解存储器管理的原理和实践操作。

二、实验目的1. 理解存储器管理的基本概念和原理;2. 学习并掌握存储器分配和回收的算法;3. 实践操作,加深对存储器管理的理解。

三、实验环境本次实验使用了一款名为“MemSim”的模拟器,它能够模拟计算机的内存分配和回收过程,并提供了一系列操作和指令供我们使用。

四、实验步骤1. 启动模拟器并加载测试程序;2. 观察内存分配过程,了解不同算法的工作原理;3. 进行内存回收操作,观察回收算法的效果;4. 分析实验结果,总结不同算法的优缺点。

五、实验结果与分析在本次实验中,我们使用了三种常见的内存分配算法:首次适应算法、最佳适应算法和最坏适应算法。

分别对应了不同的内存分配策略。

首次适应算法是最简单的一种算法,它从内存的起始位置开始查找可用的内存块,并将程序加载到第一个合适的位置。

这种算法的优点是简单易实现,但缺点是容易产生外碎片。

最佳适应算法则是从所有可用内存块中选择最小的一个来加载程序。

这样可以最大程度地减少外碎片的产生,但同时也增加了内存分配的开销。

最坏适应算法则是选择最大的可用内存块来加载程序。

这样可以减少内存碎片的产生,但会导致更多的内存浪费。

通过对比实验结果,我们可以发现不同算法在内存利用率、外碎片和内存开销等方面存在差异。

在实际应用中,我们需要根据具体情况选择合适的算法。

六、实验心得通过本次实验,我对存储器管理有了更深入的了解。

在实践操作中,我发现不同的算法在内存分配和回收过程中有不同的优缺点,需要根据具体需求进行选择。

同时,我也意识到了内存管理对计算机性能的重要性,合理的存储器管理可以提高计算机的运行效率。

在今后的学习和工作中,我将进一步深入研究存储器管理的原理和算法,并将其应用于实际项目中。

通过不断的实践和总结,我相信我能够在存储器管理方面取得更好的成果。

操作系统实验报告三存储器管理实验

操作系统实验报告三存储器管理实验

操作系统实验报告三存储器管理实验操作系统实验报告三:存储器管理实验一、实验目的本次存储器管理实验的主要目的是深入理解操作系统中存储器管理的基本原理和方法,通过实际操作和观察,掌握内存分配与回收的算法,以及页面置换算法的工作过程和性能特点,从而提高对操作系统资源管理的认识和实践能力。

二、实验环境本次实验使用的操作系统为 Windows 10,编程语言为 C++,开发工具为 Visual Studio 2019。

三、实验内容1、内存分配与回收算法实现首次适应算法(First Fit)最佳适应算法(Best Fit)最坏适应算法(Worst Fit)2、页面置换算法模拟先进先出页面置换算法(FIFO)最近最久未使用页面置换算法(LRU)时钟页面置换算法(Clock)四、实验原理1、内存分配与回收算法首次适应算法:从内存的起始位置开始,依次查找空闲分区,将第一个能够满足需求的空闲分区分配给进程。

最佳适应算法:在所有空闲分区中,选择能够满足需求且大小最小的空闲分区进行分配。

最坏适应算法:选择空闲分区中最大的分区进行分配。

2、页面置换算法先进先出页面置换算法:选择最早进入内存的页面进行置换。

最近最久未使用页面置换算法:选择最近最长时间未被访问的页面进行置换。

时钟页面置换算法:给每个页面设置一个访问位,在页面置换时,从指针指向的页面开始扫描,选择第一个访问位为0 的页面进行置换。

五、实验步骤1、内存分配与回收算法实现定义内存分区结构体,包括分区起始地址、大小、是否已分配等信息。

实现首次适应算法、最佳适应算法和最坏适应算法的函数。

编写测试程序,创建多个进程,并使用不同的算法为其分配内存,观察内存分配情况和空闲分区的变化。

2、页面置换算法模拟定义页面结构体,包括页面号、访问位等信息。

实现先进先出页面置换算法、最近最久未使用页面置换算法和时钟页面置换算法的函数。

编写测试程序,模拟页面的调入和调出过程,计算不同算法下的缺页率,比较算法的性能。

存储过程实验报告_总结(3篇)

存储过程实验报告_总结(3篇)

第1篇一、实验背景随着数据库技术的不断发展,存储过程在数据库管理中的应用越来越广泛。

存储过程是一组为了完成特定功能的SQL语句集合,它具有提高数据库性能、增强安全性、简化应用开发等优点。

为了更好地掌握存储过程的应用,我们进行了本次实验。

二、实验目的1. 理解存储过程的概念、特点和应用场景。

2. 掌握存储过程的创建、执行、修改和删除方法。

3. 学习使用存储过程实现常见的数据库操作,如数据插入、查询、更新和删除。

4. 熟悉存储过程中的流程控制语句、循环语句和游标操作。

三、实验环境1. 操作系统:Windows 102. 数据库:MySQL 5.73. 开发工具:MySQL Workbench四、实验内容1. 创建存储过程2. 执行存储过程3. 修改存储过程4. 删除存储过程5. 存储过程中的流程控制语句6. 存储过程中的循环语句7. 存储过程中的游标操作五、实验步骤1. 创建存储过程首先,我们创建一个简单的存储过程,用于查询特定部门的所有员工信息。

```sqlCREATE PROCEDURE GetEmployeeInfo(IN dept_id INT)BEGINSELECT FROM employees WHERE department_id = dept_id;END;```在此过程中,我们使用了`IN`参数,表示该参数在调用存储过程时传入。

2. 执行存储过程创建存储过程后,我们可以通过以下命令执行它:```sqlCALL GetEmployeeInfo(10);```这将查询部门ID为10的所有员工信息。

3. 修改存储过程如果需要修改存储过程,可以使用`ALTER PROCEDURE`语句。

例如,将查询条件修改为按姓名查询:```sqlALTER PROCEDURE GetEmployeeInfo(IN emp_name VARCHAR(50))BEGINSELECT FROM employees WHERE name = emp_name;END;```4. 删除存储过程删除存储过程可以使用`DROP PROCEDURE`语句。

操作系统存储管理实验报告

操作系统存储管理实验报告

操作系统存储管理实验报告操作系统存储管理实验报告引言:操作系统是计算机系统中的核心软件之一,它负责管理计算机硬件资源和提供用户与计算机之间的接口。

在操作系统中,存储管理是一个重要的子系统,它负责管理计算机的内存资源。

本实验旨在通过实际操作,深入了解操作系统的存储管理机制,并通过实验结果分析其性能和效果。

实验目的:1. 了解操作系统的存储管理机制;2. 掌握存储管理相关的概念和技术;3. 分析不同存储管理策略的优缺点;4. 通过实验验证不同策略的性能和效果。

实验内容:本次实验主要涉及以下几个方面的内容:1. 内存分配:在操作系统中,内存是计算机中的重要资源,它被划分为多个固定大小的块,每个块称为一页。

实验中,我们将学习不同的内存分配算法,如连续分配、离散分配和分页分配,并通过实验验证它们的性能和效果。

2. 内存回收:当某个进程不再需要使用内存时,操作系统需要回收该内存空间,以便其他进程使用。

实验中,我们将学习不同的内存回收算法,如最佳适应算法、最坏适应算法和首次适应算法,并通过实验比较它们的效果。

3. 虚拟内存管理:虚拟内存是一种扩展内存的技术,它将磁盘空间作为辅助存储器,将部分数据存储在磁盘上,以释放内存空间。

实验中,我们将学习虚拟内存的概念和原理,并通过实验验证其性能和效果。

实验结果与分析:通过实验,我们得到了不同存储管理策略的性能数据,并进行了分析。

在内存分配方面,连续分配在内存利用率方面表现较好,但容易产生外部碎片;离散分配能够充分利用内存空间,但需要额外的管理开销;分页分配能够灵活地分配内存,但会带来内部碎片。

在内存回收方面,最佳适应算法能够更好地利用内存空间,但需要较长的搜索时间;最坏适应算法能够减少外部碎片,但可能导致内存利用率较低;首次适应算法在搜索时间和内存利用率方面都有较好的平衡。

在虚拟内存管理方面,虚拟内存能够有效扩展内存空间,提高系统的性能和效率。

通过实验,我们发现虚拟内存的使用可以显著减少交换空间的开销,并提高系统的响应速度。

存储管理实验报告

存储管理实验报告

一、实验目的1. 理解操作系统存储管理的概念和作用。

2. 掌握存储管理的基本算法和策略。

3. 通过实验,加深对存储管理原理的理解,提高实际操作能力。

二、实验环境1. 操作系统:Windows 102. 软件环境:虚拟机软件VMware Workstation 153. 实验平台:Linux系统三、实验内容1. 存储管理概述2. 页式存储管理3. 段式存储管理4. 分段分页存储管理5. 存储管理算法四、实验步骤1. 页式存储管理实验(1)设置虚拟内存:在Linux系统中,使用`cat /proc/meminfo`命令查看内存信息,然后使用`vmstat`命令查看虚拟内存的使用情况。

(2)编写实验程序:使用C语言编写一个简单的程序,模拟页式存储管理过程。

(3)运行实验程序:编译并运行实验程序,观察程序运行过程中页面的分配、置换和回收过程。

2. 段式存储管理实验(1)设置虚拟内存:同页式存储管理实验。

(2)编写实验程序:使用C语言编写一个简单的程序,模拟段式存储管理过程。

(3)运行实验程序:编译并运行实验程序,观察程序运行过程中段页的分配、置换和回收过程。

3. 分段分页存储管理实验(1)设置虚拟内存:同页式存储管理实验。

(2)编写实验程序:使用C语言编写一个简单的程序,模拟分段分页存储管理过程。

(3)运行实验程序:编译并运行实验程序,观察程序运行过程中段页的分配、置换和回收过程。

4. 存储管理算法实验(1)编写实验程序:使用C语言编写一个简单的程序,模拟不同的存储管理算法(如FIFO、LRU、LFU等)。

(2)运行实验程序:编译并运行实验程序,观察不同算法在页面分配、置换和回收过程中的表现。

五、实验结果与分析1. 页式存储管理实验实验结果表明,页式存储管理可以将大程序离散地存储在内存中,提高内存利用率。

但页式存储管理也存在页面碎片问题,导致内存碎片化。

2. 段式存储管理实验实验结果表明,段式存储管理可以将程序按照逻辑结构划分为多个段,提高了内存的利用率。

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

昆明理工大学信息工程与自动化学院学生实验报告(2012 —2013 学年第二学期)课程名称:操作系统开课实验室:年月日一、实验目的存储管理的主要功能之一是合理地分配空间。

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

通过本次实验,要求学生通过编写和调试地址转换过程的模拟程序以加强对地址转换过程的了解,通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特点,掌握请求页式存储管理的页面置换算法。

二、实验原理及基本技术路线图(方框原理图)用C或C++语言模拟实现请求式分页管理。

要求实现:页表的数据结构、分页式内存空间的分配及回收(建议采用位图法)、地址重定位、页面置换算法(从FIFO,LRU,NRU中任选一种)。

int subareaSize[num]={8,12,16,32,24,16,64,128,40,64};//分区大小Process *pro=NULL;//保持进程信息int ProcessNum=0;//进程数目int applyProcessNum=0;//每次申请进程数目int maxApplyNum=0;//最大可申请数目int *applyIndex=NULL;//申请进程队列int totalApplyNum=0;//申请总数int *assignPointer=NULL;//已分配内存的进程队列int assignFlag=0;//分配索引,表示已申请队列已分配的进程数int exeIndex;//执行的进程号Node *subareaNode=new Node[3];//分区回收时,进程所在分区及其前,后分区信息LinkList createLinkList(int n );//建立空闲分区链Node firstFit(LinkList &head,Process pro);//首次适应算法Node nestFit(LinkList &head,Process pro,Node flag);//循环适应算法Node bestFit(LinkList &head,Process pro);//最佳适应算法Node worstFit(LinkList &head,Process pro);//最坏适应算法Node assign(LinkList &head,int orderIndex,int index,Node flagNode);//一次分区分配int assignMemory(LinkList &head);//内存分配void insertNode(LinkList &head,Node q,int index);//插入节点Node deleteNode(LinkList &head,int index);//删除节点int display(LinkList &head);//打印分区分配情况int lowAttemper(int *excursionPointer);//低级调度int findSubarea(LinkList &head,int index);//回收内存int creatProcess();//创建进程Process* randomCreatPro(int n);//随机产生进程下面是各种方法简述:(1) 最优替换算法,即OPT算法。

上面介绍的几种页面替换算法主要是以主存储器中页面调度情况的历史信息为依据的,它假设将来主存储器中的页面调度情况与过去一段时间内主存储器中的页面调度情况是相同的。

显然,这种假设不总是正确的。

最好的算法应该是选择将来最久不被访问的页面作为被替换的页面,这种替换算法的命中率一定是最高的,它就是最优替换算法。

要实现OPT算法,唯一的办法是让程序先执行一遍,记录下实际的页地址流情况。

根据这个页地址流才能找出当前要被替换的页面。

显然,这样做是不现实的。

因此,OPT算法只是一种理想化的算法,然而,它也是一种很有用的算法。

实际上,经常把这种算法用来作为评价其它页面替换算法好坏的标准。

在其它条件相同的情况下,哪一种页面替换算法的命中率与OPT算法最接近,那么,它就是一种比较好的页面替换算法。

(2)先进先出算法,即FIFO算法(First-In First-Out algorithm)。

这种算法选择最先调入主存储器的页面作为被替换的页面。

它的优点是比较容易实现,能够利用主存储器中页面调度情况的历史信息,但是,没有反映程序的局部性。

因为最先调入主存的页面,很可能也是经常要使用的页面。

(3) 最久没有使用算法,即LRU算法(Least Recently Used algorithm)。

这种算法把近期最久没有被访问过的页面作为被替换的页面。

它把LFU算法中要记录数量上的多"与"少简化成判断"有"与"无",因此,实现起来比较容易。

(4) 近期最少使用算法,即LFU算法(Least Frequently Used algorithm)。

这种算法选择近期最少访问的页面作为被替换的页面。

显然,这是一种非常合理的算法,因为到目前为止最少使用的页面,很可能也是将来最少访问的页面。

该算法既充分利用了主存中页面调度情况的历史信息,又正确反映了程序的局部性。

但是,这种算法实现起来非常困难,它要为每个页面设置一个很长的计数器,并且要选择一个固定的时钟为每个计数器定时计数。

在选择被替换页面时,要从所有计数器中找出一个计数值最大的计数器。

因此,通常采用如下一种相对比较简单的方法。

(5) 最近未使用法缺页中断率= 缺页中断次数总的页面引用次数*100%三、所用仪器、材料(设备名称、型号、规格等)。

计算机一台四、实验方法、步骤# include <iostream># include <cmath># include <iomanip.h># include <time.h># include <conio.h>#define Size 4#define num 10typedef int byte;typedef struct {byte subareaSize;//分区大小int startLoc;//起始地址int index;// 分区号}SubareaTable;//分区表typedef struct node{// 结点SubareaTable subarea;// 分区struct node *next;int status;//状态位0(空闲)1(使用)}*Node,*LinkList;typedef struct {byte processSize;int subareaIndex;//保存分区号int status;//进程状态,0(新建)1(执行)-1(终止)-2(未绪。

申请但没有分配内存)2(就绪,已分配内存) }Process;//进程int subareaSize[num]={8,12,16,32,24,16,64,128,40,64};//分区大小Process *pro=NULL;//保持进程信息int ProcessNum=0;//进程数目int applyProcessNum=0;//每次申请进程数目int maxApplyNum=0;//最大可申请数目int *applyIndex=NULL;//申请进程队列int totalApplyNum=0;//申请总数int *assignPointer=NULL;//已分配内存的进程队列int assignFlag=0;//分配索引,表示已申请队列已分配的进程数int exeIndex;//执行的进程号Node *subareaNode=new Node[3];//分区回收时,进程所在分区及其前,后分区信息LinkList createLinkList(int n );//建立空闲分区链Node firstFit(LinkList &head,Process pro);//首次适应算法Node nestFit(LinkList &head,Process pro,Node flag);//循环适应算法Node bestFit(LinkList &head,Process pro);//最佳适应算法Node worstFit(LinkList &head,Process pro);//最坏适应算法Node assign(LinkList &head,int orderIndex,int index,Node flagNode);//一次分区分配int assignMemory(LinkList &head);//内存分配void insertNode(LinkList &head,Node q,int index);//插入节点Node deleteNode(LinkList &head,int index);//删除节点int display(LinkList &head);//打印分区分配情况int lowAttemper(int *excursionPointer);//低级调度int findSubarea(LinkList &head,int index);//回收内存int creatProcess();//创建进程Process* randomCreatPro(int n);//随机产生进程LinkList createLinkList(int n){//建立空闲分区链cout<<" -------------创建分区--------------"<<endl; LinkList head;Node p;head=(LinkList)malloc(sizeof(node));if(head==NULL){cout<<"头结点分配错误"<<endl;return NULL;}head->next=NULL;//链表尾巴设置为NULLLinkList q=head;int start=0;for(int i=1;i<=n;i++){p=(Node)malloc(sizeof(node));if(p==NULL){cout<<"节点分配错误"<<endl;return NULL;}p->next=q->next;q->next=p;q=p;p->subarea.index=i;p->subarea.subareaSize=subareaSize[i-1];//分区表赋值大小p->subarea.startLoc=start;p->status=0;start+=subareaSize[i-1];}cout<<"分区创建成功"<<endl;return head;}Node firstFit(LinkList &head,Process pro){//首次适应算法Node p=head->next;//遍历结点,返回结点,从第一个结点开始遍历if(p==NULL){cout<<"空闲链表不存在"<<endl;return NULL;}else{do{if(p->status==0&&p->subarea.subareaSize>=pro.processSize){break;}p=p->next;}while(p!=NULL);if(p==NULL){//没找到合适的结点return head;}return p;}}Node nestFit(LinkList &head,Process pro,Node flag){//循环适应算法Node p=flag->next;//遍历结点while(p!=NULL){if(p->status==0&&p->subarea.subareaSize>=pro.processSize){break;}p=p->next;}if(p==NULL){//遍历到链表结尾p=head;//从头开始遍历while(p!=flag){//标记结点p=p->next;if(p->status==0&&p->subarea.subareaSize>=pro.processSize){break;}}if(p==flag){//正常跳出循环,没有合适的结点可分配return head;}else{return p;// 在flag结点前找到一合适的结点分配}}else{return p;// 在flag结点后找到一合适的结点分配}}Node bestFit(LinkList &head,Process pro){//最佳适应算法Node p=head->next;//遍历结点,返回结点,从第一个结点开始遍历Node q;//返回最佳空闲结点int leave;//剩余空间int count=0;//计数器if(p==NULL){cout<<"空闲链表不存在"<<endl;return NULL;}else{do {if(p->status==0&&p->subarea.subareaSize>=pro.processSize){count++;if(count==1){//第一个可以分配的空闲分区leave=p->subarea.subareaSize-pro.processSize;q=p;}else if(count>1){if(p->subarea.subareaSize-pro.processSize<leave){//更适合的结点leave=p->subarea.subareaSize-pro.processSize;q=p;}}}p=p->next;}while(p!=NULL);return q;}}Node worstFit(LinkList &head,Process pro){//最坏适应算法Node p=head->next;//遍历结点,返回结点,从第一个结点开始遍历Node q;//返回最大空闲结点int count=0;//计数器if(p==NULL){cout<<"空闲链表不存在"<<endl;return NULL;}else {// 开始遍历do {if(p->status==0){count++;if(count==1){//第一个空闲区q=p;}else{//非第一个空闲区if(p->subarea.subareaSize>q->subarea.subareaSize){//当前结点大于前面最大结点q=p;}}}p=p->next;}while(p!=NULL);if(q->subarea.subareaSize>=pro.processSize){return q;}else{cout<<"进程大小大于最大分区,无法分配"<<endl;return head;}}}void insertNode(LinkList &head,Node q,int index){Node p;//遍历结点int j=1;if(head==NULL){cout<<"链表为空";return;}p=head->next;for(;p;p=p->next){j++;if(j>=index)break;}q->next=p->next;p->next=q;//插入完成j=q->subarea.index;//j保持q的分区号q=q->next;//开始修改分区号j=q->subarea.index;while(q!=NULL){q->subarea.index=j+1;q=q->next;j++;}}Node deleteNode(LinkList &head,int index){ Node q;//保存要删掉的节点Node p=head;//遍历的节点int count=0;while(p&&count<index-1){p=p->next;count++;}q=p->next;p->next=q->next;return q;}int findSubarea(LinkList &head,int index){ Node p=head->next;//遍历结点if(p==NULL){cout<<"空闲链表不存在"<<endl;return 0;}else{int j=1;for(;p;j++){p=p->next;if(j>=index-1)break;}for(int i=0;i<3;i++){subareaNode[i]=p;p=p->next;}return 1;}}int display(LinkList &head){//打印分区分配情况cout<<" -------------分区信息--------------"<<endl;Node p;if(head==NULL){cout<<"分区未创建,请先创建分区"<<endl;return 0;}else{p=head->next;cout.fill(' ');while(p!=NULL){cout.width(3);cout<<p->subarea.index<<"分区的大小:"<<setw(5)<<p->subarea.subareaSize<<"KB "<<"分区开始位置:"<<setw(6)<<p->subarea.startLoc<<"是否空闲:"<<setw(4)<<p->status<<endl;p=p->next;}return 1;}}int displayProcess(){cout<<" -------------进程信息--------------"<<endl;if(pro==NULL){cout<<"进程未创建,请先创建进程"<<endl;return 0;}for(int i=0;i<ProcessNum;pro++,i++){cout<<i+1<<"号进程大小:"<<setw(6)<<pro->processSize<<" 进程状况:"<<setw(6);if(pro->status==0){cout<<"创建";}else if(pro->status==1){//进程状态cout<<"执行";}else if(pro->status==-1){cout<<"终止";}else if(pro->status==2){cout<<"就绪";}else if(pro->status==-2){cout<<"未绪";}cout<<endl;}pro-=ProcessNum;return 1;}int applyforProcess(){cout<<" -------------申请进程--------------"<<endl;int index;if(pro==NULL){cout<<"进程未创建,请先创建进程"<<endl;return 0;}cout<<"输入申请进程的数目:";cin>>applyProcessNum;while(applyProcessNum>maxApplyNum){//申请数目大于最大可申请数目cout<<"申请进程数目大于可申请进程数目,不合法"<<endl;cout<<"请重新输入申请进程数:";cin>>applyProcessNum;}displayProcess();for(int i=0;i<applyProcessNum;){cout<<"请输入需要申请的进程(创建进程才能申请):";cin>>index;pro+=(index-1);//修改指针if(pro->status==0){cout<<index<<"号进程申请成功"<<endl;applyIndex[i+totalApplyNum]=index-1;//保持申请进程的偏移量pro->status=-2;//改状态i++;maxApplyNum--;}else{cout<<index<<"号进程不为创建状态,重新申请"<<endl;}pro-=(index-1);//回首址}totalApplyNum+=applyProcessNum;return 1;}int assignMemory(LinkList &head){//分配内存int n;Node flagNode;if(applyProcessNum==0||head==NULL){cout<<"未申请进程或未建分区....."<<endl;return 0;}do{cout<<"**********内存分配**********"<<endl;cout<<setw(10)<<"1.首次适应算法"<<endl;cout<<setw(10)<<"2.循环适应算法"<<endl;cout<<setw(10)<<"3.最佳适应算法"<<endl;cout<<setw(10)<<"4.最坏适应算法"<<endl;cout<<"**************************"<<endl;cout<<"请选择:";cin>>n;}while(n<1||n>4);int count=0;//第一次分配,从头结点开始,其他重上次分配的节点开始applyIndex+=assignFlag;//从分配资源的进程开始分配for(int i=assignFlag;i<totalApplyNum;i++,applyIndex++){if(n!=2){assign(head,n,*applyIndex,NULL);}//head头结点(链表),n(分配算法)NULL(n!=2无作业),*applyIndex申请进程的偏移指针else if(n==2){if(count==0){flagNode=assign(head,n,*applyIndex,head);count++;}else{flagNode=assign(head,n,*applyIndex,flagNode);}}assignPointer[i]=*applyIndex;//分配的进程进已分配进程队列}applyIndex-=totalApplyNum;//申请进程的偏移指针回首址assignFlag=totalApplyNum;//修改分配数;return 1;}Node assign(LinkList &head,int orderIndex,int index,Node flagNode){pro+=index;Process process=*pro;Node assignNode;switch(orderIndex){case 1:{assignNode=firstFit(head,process);break;}case 2:{assignNode=nestFit(head,process,flagNode);break;}case 3:{assignNode=bestFit(head,process);break;}case 4:{assignNode=worstFit(head,process);break;}}pro->subareaIndex=assignNode->subarea.index;//保存进程分配的分区号pro->status=2;//修改状态pro-=index;//指针回到起始位置if(assignNode!=NULL){//找到分配分区if(assignNode->subarea.subareaSize-process.processSize<=Size){//不再切割的分区assignNode->subarea.subareaSize=process.processSize;//修改分区大小}else if(assignNode->subarea.subareaSize-process.processSize>Size){//可再划分分区Node node=(Node)malloc(sizeof(node));SubareaTable *subarea=(SubareaTable*)malloc(sizeof(SubareaTable));//划分新的分区subarea->index=assignNode->subarea.index+1;//分区号subarea->subareaSize=assignNode->subarea.subareaSize-process.processSize;//分区大小subarea->startLoc=assignNode->subarea.startLoc+process.processSize;node->status=0;//分区状态node->subarea=*subarea;insertNode(head, node, assignNode->subarea.index+1);//插入空闲链表}assignNode->status=1;// 修改分区使用return assignNode;}else{return NULL;}}void amendNodedata(Node p,Node q){if(p->status==0&&q->status==0){// 前后两分区都不是空闲分区int j=p->subarea.index;//分区号p->subarea.subareaSize+=(q->subarea.subareaSize+subareaNode[1]->subarea.subareaSize);//修改分区大小p->next=q->next;//修改指针;while(p!=NULL){j++;p->subarea.index=j;p=p->next;}}else if(p->status==1&&q->status==0){//前未空闲后空闲p=subareaNode[1];int j=p->subarea.index;p->subarea.subareaSize+=q->subarea.subareaSize;p->next=q->next;while(p!=NULL){j++;p->subarea.index=j;p=p->next;}}else if(p->status==0&&q->status==1){//前空闲后未空闲int j=p->subarea.index;p->subarea.subareaSize+=subareaNode[1]->subarea.subareaSize;p->next=subareaNode[1]->next;while(p!=NULL){j++;p->subarea.index=j;p=p->next;}}}int callbackMemory(LinkList &head, int index){char n;cout<<index+1<<"进程正在执行...."<<endl;cout<<"进程大小为"<<setw(5)<<(pro+index)->processSize<<" 分配的分区号"<<(pro+index)->subareaIndex<<endl;do{cout<<"是否结束进程Y/N 请输入(y/n)";cin>>n;cout<<endl;}while(n!='y'||n!='Y'||n!='n'||n!='N');if(n=='y'||n=='Y'){findSubarea(head,(pro+index)->subareaIndex);if(subareaNode[2]!=NULL){if(subareaNode[0]->status==1&&subareaNode[2]->status==1){subareaNode[0]->status=0;}else {amendNodedata(subareaNode[0],subareaNode[2]);}else if(subareaNode[0]==NULL){if(subareaNode[0]->status==0){subareaNode[0]->subarea.subareaSize+=subareaNode[1]->subarea.subareaSize;subareaNode[0]->next=subareaNode[2];}else{subareaNode[0]->status=0;}}return 1 ;}else{cout<<"您没结束进程,进程不释放,分区不回收"<<endl;return 0;}}int lowAttemper(int *excursionPointer){cout<<" -------------低级调度--------------"<<endl;if(*excursionPointer<0){cout<<"没有已分配好资源的进程";return 0;}else{int n;displayProcess();cout<<"请选择一个就绪进程进入CPU";cin>>n;cout<<endl;}while(n<1||n>ProcessNum||(pro+n-1)->status!=2);(pro+n-1)->status=1;//进程状态改变exeIndex=n-1;cout<<"CPU正在调度...."<<endl;cout<<n<<"进程获得处理机,开始执行"<<endl;return 1;}}int creatProcess(){cout<<" -------------创建进程--------------"<<endl; cout<<"输入进程数目:";cin>>ProcessNum;applyIndex=new int[ProcessNum];//初始化进程申请队列assignPointer=new int[ProcessNum];//初始化进程分配队列maxApplyNum=ProcessNum;pro=randomCreatPro(ProcessNum);cout<<"进程正在创建......"<<endl;return 1;}Process* randomCreatPro(int n){Process *process=new Process[n];srand((unsigned)time(NULL));//播一次种for(int i=0;i<n;i++){process[i].processSize=1+rand()%128;//随机产生进程的大小process[i].status=0;//初始化进程状况process[i].subareaIndex=-1;//初始化分区号,-1未分配,进程在外存上}return process;}int main(){int flg,i;LinkList head;flg=1;while (flg){system ("cls");cout<<"*********************计算机内存管理****************"<<endl;cout<<setw(30)<<"1.创建进程"<<endl;cout<<setw(30)<<"2.进程信息"<<endl;cout<<setw(30)<<"3.进程申请"<<endl;cout<<setw(30)<<"4.分区创建"<<endl;cout<<setw(30)<<"5.内存分配"<<endl;cout<<setw(30)<<"6.内存回收"<<endl;cout<<setw(30)<<"7.打印分区"<<endl;cout<<setw(30)<<"8.低级调度"<<endl;cout<<setw(30)<<"0.系统退出"<<endl;cout<<"***************************************************"<<endl;cout<<"请选择:";cin>>i;switch (i){case 1: {if(creatProcess()==1){cout<<"进程创建完成"<<endl;}break;}case 2:{displayProcess();break;}case 3:{applyforProcess();break;}case 4:{head=createLinkList(num);break;}case 5:{assignMemory(head);break;}case 6:{callbackMemory(head,exeIndex);break;}case 7:{display(head);break;}case 8:{lowAttemper(assignPointer);break;}case 0:{flg=0;cout<<"系统退出";}}if (i!=0) {printf ("you can press any key to continue!");getch();}system ("cls");printf("\n\nthank you use it,good bye!!\n");}return 0;}五、实验过程原始记录(数据、图表、计算等)六、实验结果、分析和结论(误差分析与数据处理、成果总结等。

相关文档
最新文档