操作系统课程设计之请求式面页管理
请求分页式存储管理课程设计java

请求分页式存储管理课程设计java在Java中实现分页式存储管理,可以设计一个简单的模拟系统,如下面的概念框架。
假设我们有一组固定大小的页和一组固定大小的内存帧。
分页算法的任务是当请求来时,找到一个空闲的内存帧并分配给请求的页。
下面是一个简单的课程设计方案:定义页面和帧的概念:使用类来表示页和帧。
class Page {// ...}class Frame {// ...}创建页表和帧池:使用集合来表示页表和帧池Map<Page, Frame> pageTable = new HashMap<>();List<Frame> framePool = new ArrayList<>();实现分页算法:当请求到来时,找到一个空闲的帧并分配给请求的页。
如果没有空闲的帧,那么就需要使用某种页面替换算法(如最少使用算法或最近最久未使用算法)来选择一个帧进行替换。
public Frame allocateFrame(Page page) {// ...}处理页错误:如果请求的页不在内存中,那么就会产生页错误。
在这种情况下,需要将页面从磁盘加载到内存中。
public void handlePageFault(Page page) {// ...}这只是一个非常基础的框架,你可能需要添加更多的功能,比如模拟从磁盘读取页面的延迟,或者记录并显示内存的使用情况等。
记住,这个项目是一个模拟的分页存储管理系统,所以实际的实现细节可能会有所不同。
在实际的操作系统中,分页存储管理涉及到很多复杂的问题,比如虚拟内存管理、页面替换算法、页表管理等。
计算机操作系统实验教程

计算机操作系统实验教程徐 慧中国矿业大学(北京)机电与信息工程学院计算机系二0 0四年四月实验简介 (2)实验一进程管理 (3)一、实验目的 (3)二、实验预备内容 (3)三、实验内容 (3)四、预备知识 (3)五实验指导 (4)实验二进程间的通信 (5)一、实验目的 (5)二、实验预备内容 (5)三、实验内容 (5)四、实验预备知识 (5)五、实验指导 (9)实验三存储管理 (10)一、实验目的 (10)二、实验内容 (10)三、实验预备知识 (10)四、实验指导 (13)实验四文件系统设计 (14)一、实验目的 (14)二、实验内容 (14)三、实验提示 (14)四、实验指导 (14)实验简介1.学时:16学时2.先修课程:计算机导论 ,高级语言程序设计 , 数据结构3.课程性质:专业基础必修课4.适合专业:计算机科学与技术5.内容简介:操作系统上机课程通Linux操作系统各自的编程接口,提供编程实例,由此加深学生对操作系统工作原理的领会和对操作系统实现方法的理解,并且使学生在程序设计方面得到基本的训练。
上机课程主要针对课本重点内容,以提高学生的动手能力,加深学生对相关的内容的理解而展开的实验课程。
在Linux环境下提供了关于操作系统的命令接口程序shell的编制、存储管理相关内容的实路、作业调研系统以及虚拟磁盘文件系统管理4个实验。
实验环境是基于Linux操作系统的。
在计算机软硬件课程的设置上,它起着承上启下的作用。
其特点是概念多、较抽象和涉及面广,其整体实现思想和技术又往往难于理解。
6.参考书:张尧学,史美林 《计算机操作系统课程设计实验指导》 清华大学出版社 2000年实验一 进程管理一、实验目的(1)加深对进程概念的理解,明确进程的程序的区别;(2)可进一步认识并发执行的实质;(3)分析进程争用资源的现象,学习解决进程互斥的方法;(4)了解LINUX系统中进程通信的进本原理;二、实验预备内容(1)阅读LINUX 的sched.h源码文件,加深对进程管理概念的理解;(2)阅读LINUX的fork.c源码,分析进程的创建过程;三、实验内容(1)进程创建编写一段程序,使用系统调用fork()创建两个子进程.(2)进程的控制修改以编写的程序,将每个进程输出一个字符改为输出一句话,观察程序执行时屏幕上出现的现象;(3)编写一段程序实现软中断;(4)进程的管道通信;四、预备知识现代操作系统的重要特点是程序的并发执行,及系统所拥有的资源被共享和系统用户随机地使用系统。
14计算机科学与技术(专升本)-操作系统-课程设计教学大纲

《操作系统》课程设计教学大纲英文名称: Operating System课程编码:C047101计划周数:1周课程设计学分:1学分先修课程:计算机导论,高级语言程序设计,数据结构,汇编语言程序设计适用专业:计算机科学与技术(专升本)开课单位:计算机科学与技术系撰写人:何爱华审核人:姚保峰制定时间:2014年8月一、本课程设计的性质与目的《操作系统》是计算机科学与技术(专升本)专业的核心专业课,“操作系统课程设计”是理解和巩固操作系统基本理论、原理和方法的重要的实践环节。
《操作系统》课程主要讲述的内容是计算机操作系统的基本原理及组成,操作系统中常用的设计技巧和方法。
它与计算机原理、编译原理、汇编语言、计算机网络、程序设计等专业课程关系十分密切。
本课程设计的目的综合应用学生所学知识,建立系统和完整的计算机系统概念,理解和巩固操作系统基本理论、原理和方法;在算法基础上,解决实际问题,提高学生实际应用、编程的能力。
二、本课程设计的主要内容实验的内容侧重于对操作系统原理的模拟实现,主要包括对进程管理、内存管理、文件系统和设备管理的实践内容。
主要任务是实现操作系统和相关系统软件的设计,其中涉及进程创建,同步,进程间的通信,存储管理,文件系统等操作系统概念。
,主要内容如表1所示:表1 课程设计内容序号内容1 进程的管道通讯;编制一个程序,程序中创建一个子进程。
然后父子进程各自独立运行,父进程不断地在标准输入设备上读入小写字母,写入管道。
子进程不断地从管道中读取字符,转换为大写字母后输出到标准输出设备上。
当读到x时,结束。
2 信号量实现的同步互斥机制:编制一个程序,程序中创建5个子进程,代表五位哲学家,然后父进程结束。
使用信号量机制解决哲学家进餐问题。
3 页面置换算法:请求页式管理是一种常用的虚拟存储管理技术。
本设计通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特点,掌握请求页式管理的页面置换算法。
操作系统课程设计报告

实践课设计报告课程名称操作系统课程设计模拟设计内存管理中的地址题目转换(动态分区、页式十进制)学院班级学号姓名指导教师年月日课程设计任务书学生姓名:专业班级:指导教师:工作单位:题目: 模拟设计内存管理中的地址转换(动态分区、页式十进制)初始条件:1.预备内容:阅读操作系统的内存管理章节内容,理解动态分区、页式、段式和段页式存储管理的思想及相应的分配主存的过程。
2.实践准备:掌握一种计算机高级语言的使用。
要求完成的主要任务:(包括课程设计工作量及其技术要求,以及说明书撰写等具体要求)1.下列内部存储器管理中地址转换,在完成指定存储管理技术中的地址转换基础上还可以选择其它内部存储器管理中的地址转换进行模拟设计并实现:⑴动态分区方案,用最先适用算法对作业实施内存分配,然后把作业地址空间的某一逻辑地址转换成相应的物理地址。
能够处理以下的情形:输入某一逻辑地址,程序能判断地址的合法性,如果合法,计算并输出相应的物理地址。
如果不能计算出相应的物理地址,说明原因。
⑵页式存储管理中逻辑地址到物理地址的转换(十进制)。
能够处理以下的情形:输入某一十进制逻辑地址,能检查地址的合法性,如果合法进行转换,否则显示“地址非法”;物理地址用十进制表示。
⑶页式存储管理中逻辑地址到物理地址的转换(八进制)。
能够处理以下的情形:输入某一八进制逻辑地址,能检查地址的合法性,如果合法进行转换,否则显示“地址非法”;物理地址用八进制表示。
⑷页式存储管理中逻辑地址到物理地址的转换(十六进制)。
能够处理以下的情形:输入某一十六进制逻辑地址,能检查地址的合法性,如果合法进行转换,否则显示“地址非法”;物理地址用十六进制表示。
⑸段式存储管理中逻辑地址到物理地址的转换。
能够处理以下的情形:指定内存的大小,进程的个数,每个进程的段数及段大小;能检查地址的合法性,如果合法进行转换,否则显示地址非法的原因。
⑹段页式存储管理中逻辑地址到物理地址的转换。
苏州大学操作系统原理课程试卷(3套)含答案

苏州大学操作系统原理课程试卷(一)答案共4页一、填空题(20分,每空1分)1、进程通信的常用方式有直接通信和间接通信等。
2、如果P(S1)和P(S2)两个操作在一起,那么P操作的顺序至关重要,一个同步P操作与一个互斥P操作在一起时同步P操作在互斥P操作前。
而两个V操作的次序无关紧要。
3、P(S):表示申请一个资源;V(S)表示释放一个资源。
信号量的初值应该大于等于0 。
4、在请求式分页系统中,页框的分配中有一种方式称为固定分配。
固定分配有两种不同的方式,分别是平均分配和按比率分配。
5、在请求式分页存储管理系统中,不能在计算机中实现的页面淘汰算法是最佳算法,选择淘汰不再使用或最远的将来才使用的页的算法是先进先出算法,选择淘汰在主存驻留时间最长的页的算法是最近最少使用。
6、将作业地址空间中的逻辑地址转换为主存中的物理地址的过程称为地址转换。
7、访问磁盘时间由三部分组成寻道时间、旋转延迟时间和传输时间。
8、I/O设备的控制方式有轮询、中断和DMA等。
二、判断题(20分,每题4分,请说明正确与否的理由)1、分布式系统就是紧偶合系统。
错。
分布式系统是松散偶合系统。
2、在一个只有单个CPU的计算机中,进程不能并行操作。
错。
一个进程在利用CPU运行,另一个进程可以同时进行I/O操作,它们是并行的。
3、线程可以分为内核级(Kernel Thread)和用户级(User Thread)两种,操作系统不可以直接调度用户级的线程。
对。
4、有m个进程的操作系统出现死锁时, 死锁进程的个数为1<k≤m。
对。
5、在虚存系统中, 只要磁盘空间无限大, 作业就能拥有任意大的编址空间。
错。
作业的编制空间是由计算机的字长决定的。
三、简答题(20分,每题5分)1、为什么要在设备管理种引入缓冲技术?答:1)解决设备间速度的不匹配;2)减少中断频率;3)提高并行性。
2、CPU调度可能发生的时机有哪些?答:CPU调度可能发生在当一个进程:●从运行转到等待●运行转到就绪●从等待转到就绪●终止运行3、同步机构应遵循哪些原则?答:使用互斥区的原则:有空让进:当无进程在互斥区时,任何有权使用互斥区的进程可进入。
操作系统课程设计2013

操作系统课程设计1、(难度系数3)模拟UNIX(linux)文件系统[问题描述]在任一OS下,建立一个大文件,把它假象成一张盘,在其中实现一个简单的模拟UNIX文件系统。
[基本要求]1).在现有机器硬盘上开辟20M的硬盘空间,作为设定的硬盘空间。
2).编写一管理程序对此空间进行管理,以模拟UNIX(或linux)文件系统,具体要求如下:(1)要求盘块大小1k正规文件(2) i 结点文件类型目录文件(共1byte) 块设备管道文件。
物理地址(索引表)共有13个表项,每表项2byte。
文件长度4byte。
联结计数1byte(3)0号块超级块栈长度50空闲盘块的管理:成组链接( UNIX)或位示图法(Linux)(4)每建一个目录,分配4个物理块文件名14byte(5)目录项信息i 结点号2byte(6)结构:0#:超级块1#-20#号为目录区20#-30#号索引节点区(7)功能:1、初始化2、建立文件(需给出文件名,文件长度)3、建立子目录4、打开文件(显示文件所占的盘块)5、删除文件6、删除目录7、显示目录(即显示目录下的信息,包括文件、子目录等)8、显示整个系统信息2、模拟文件系统(难度系数2)[问题描述]在任一OS下,建立一个大文件,把它假象成一张盘,在其中实现一个简单的小型文件系统。
[基本要求]该小型文件系统没有子目录机制,文件连续分配,不考虑分区。
做一个简单的操作界面,提供五条简单的命令:显示文件名dir 、创建文件cf、拷贝文件copy、删除文件del , 文件改名rename 。
进一步增强:上题中的文件系统功能:文件系统不连续分配,可以有子目录机制,(如两级子目录机制)。
3、设计一个请求页式存储管理方案。
(难度系数1)并编写模拟程序实现之。
产生一个需要访问的指令地址流。
它是一系列需要访问的指令的地址。
为不失一般性,你可以适当地(用人工指定地方法或用随机数产生器)生成这个序列,使得 50%的指令是顺序执行的。
操作系统课程设计(完整规范版)

操作系统课程设计(完整规范版)一、设计目的操作系统课程设计旨在让学生深入了解操作系统的基本原理,掌握操作系统设计与实现的基本方法,培养学生在操作系统领域的实际动手能力和创新思维。
通过本次课程设计,学生应能够:1. 理解操作系统的功能、结构和关键技术;2. 学会分析实际操作系统的性能和特点;3. 设计并实现一个简单的操作系统模块或功能;4. 提高团队协作和沟通能力。
二、设计要求1. 设计内容:根据课程所学,选择一个具有实际意义的操作系统模块进行设计与实现。
模块可包括:进程管理、内存管理、文件系统、设备管理等。
2. 设计规范:遵循软件工程的基本原则,确保代码的可读性、可维护性和可扩展性。
3. 团队协作:本次课程设计以小组为单位进行,每组35人。
小组成员需明确分工,共同完成设计任务。
(2):包括所有设计文件、代码及相关文档;(3)演示PPT:汇报课程设计成果,阐述设计思路、实现过程及创新点。
三、设计流程1. 需求分析:分析所选操作系统模块的功能需求,明确设计目标。
2. 系统设计:根据需求分析,设计系统架构,划分模块,确定各模块的功能和接口。
3. 编码实现:按照系统设计,编写代码,实现各模块功能。
4. 测试与调试:对实现的系统模块进行功能测试、性能测试和兼容性测试,确保系统稳定可靠。
5. 优化与改进:根据测试结果,对系统进行优化和改进。
7. 演示与答辩:制作演示PPT,汇报课程设计成果,回答评委提问。
四、评分标准1. 设计报告(30%):内容完整、结构清晰、表述准确、格式规范。
2. 代码质量(40%):代码可读性、可维护性、可扩展性、创新性。
3. 演示与答辩(20%):PPT制作、汇报效果、回答问题。
4. 团队协作(10%):分工明确、协作高效、沟通交流。
五、预期成果1. 理论与实践相结合:将课堂上所学的操作系统理论知识运用到实际设计中,加深对操作系统的理解。
2. 技能提升:提高编程能力,掌握操作系统核心模块的设计与实现技巧。
模拟页式存储管理 操作系统课程设计

计算机科学与技术学院操作系统课程设计报告课题:模拟页式存储管理姓名:学号:同组姓名:专业班级:网工10101指导教师:刘国清设计时间: 2013-6-25 评阅意见:评定成绩:指导老师签名:年月日目录一、目的和要求 (2)1、设计目的 (2)2、设计要求 (2)二、设计思路及过程 (2)1、概要设计 (2)2、过程设计 (3)三、数据定义 (5)四、核心代码 (5)五、运行截图 (8)六、小结 (10)七、参考文献 (11)附录 (12)一、目的和要求1、设计目的通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特点,掌握请求页式存储管理的页面置换算法。
2、设计要求根据模拟的页式管理设计,掌握在页式存储管理中最基本的三种页面调度算法FIFO、LRU以及OPT。
但在三种算法中均要求在调度程序中产生的页面序列是随机产生的,而不是人为的输入,在执行时只需改变页面的大小及内存容量就可以得到不同的页面序列,另外还需要说明随机的性能和其性能可能对算法的影响,并对随机性要有一定的参数控制能力。
此外,计算并输出FIFO、LRU以及OPT算法在不同内存容量下的命中率。
根据方法的执行过程,编写一个解决上述问题的程序,显示访问每个值页面中的值。
具体参数:访问串的长度,访问串,页面个数。
分别用3种不同的方法实现页面的置换,并输出相关信息。
二、设计思路及过程1、概要设计1.1 问题概述根据三种不同的置换算法,依据其不同的算法方式,分别计算该算法在不同情况下的命中率,并显示各页面的变化情况。
1.2 内容分析对于该课程设计中模拟的页式存储管理的页面置换过程,只要掌握其中最基本的三种算法,包括FIFO、LRU及OPT。
但最重要的一点就是要求产生随机序列,所以在编写程序时要采用控制产生随机值的种子数函数,如此能产生随机的访问序列。
另外,不能在执行完一次操作后就只能进行另外一种算法的操作,必须还要有更加详细的操作,比如:是否要重新得到新序列?还是要不改变访问序列而只改变访问串的内存容量?抑或是不操作就退出该算法以进行下一种调度算法?因此,在执行完每次操作后都必须要有提示语,看是否进入更细节的操作,还是退出本次算法的操作以进入下一种算法的调度。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一、目的与要求1、目的近年来,由于大规模集成电路(LSI )和超大规模集成电路(VLSI )技术的发展,使存储器的容量不断扩大,价格大幅度下降。
但从使用角度看,存储器的容量和成本总受到一定的限制。
所以,提高存储器的效率始终是操作系统研究的重要课题之一。
虚拟存储技术是用来扩大内存容量的一种重要方法。
学生应独立地用高级语言编写几个常用的存储分配算法,并设计一个存储管理的模拟程序,对各种算法进行分析比较,评测其性能优劣,从而加深对这些算法的了解。
任务三采用最佳淘汰算法(OPT)实现,任务四采用最近最少使用页淘汰算法(LRU)实现。
2、 要求为了比较真实地模拟存储管理,可预先生成一个大致符合实际情况的指令地址流。
然后模拟这样一种指令序列的执行来计算和分析各种算法的访问命中率。
二、示例1、题目 本示例是采用页式分配存储管理方案,并通过分析计算不同页面淘汰算法情况下的访问命中率来比较各种算法的优劣。
另外也考虑到改变页面大小和实际存储器容量对计算结果的影响,从而可为算则好的算法、合适的页面尺寸和实存容量提供依据。
本程序是按下述原则生成指令序列的:(1) 50%的指令是顺序执行的。
(2) 25%的指令均匀散布在前地址部分。
(3) 25%的指令均匀散布在后地址部分。
示例中选用最佳淘汰算法(OPT )和最近最少使用页面淘汰算法(LRU )计算页面命中率。
公式为页地址流长度页面失效次数命中率-=1 假定虚存容量为32K ,页面尺寸从1K 至8K ,实存容量从4页至32页。
2、 算法与框图(1) 最佳淘汰算法(OPT)。
这是一种理想的算法,可用来作为衡量其他算法优劣的依据,在实际系统中是难以实现的,因为它必须先知道指令的全部地址流。
由于本示例中已预先生成了全部的指令地址流,故可计算出最佳命中率。
该算法的准则是淘汰已满页表中不再访问或是最迟访问的的页。
这就要求将页表中的页逐个与后继指令访问的所有页比较,如后继指令不在访问该页,则把此页淘汰,不然得找出后继指令中最迟访问的页面淘汰。
可见最佳淘汰算法要花费较长的运算时间。
(2) 最近最少使用页淘汰算法(LRU)。
这是一种经常使用的方法,有各种不同的实施方案,这里采用的是不断调整页表链的方法,即总是淘汰页表链链首的页,而把新访问的页插入链尾。
如果当前调用页已在页表内,则把它再次调整到链尾。
这样就能保证最近使用的页,总是处于靠近链尾部分,而不常使用的页就移到链首,逐个被淘汰,在页表较大时,调整页表链的代价也是不小的。
(3) 程序框图如下图2所示。
产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产size=1assigned=4产产产产产产Alg Alg=OPT/LRU产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产产OPT LRU产产图2计算页面命中率框图3、程序运行结果格式(1) 程序运行结果格式THE VIRTUAL ADDRESS STREAM AS FOLLOWS:a[0] =16895 a[1]=16896 a[2]=16897 a[3]=16302a[4]=25403 a[5]=13941 a[6]=13942 a[7]=8767………………A[252]=23583 a[253]=20265 a[254]=20266 a[255]=20267= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = The algorithm is:optPAGE NUMBER WITH SIZE 1k FOR EACH ADDRESS IS:pageno[0]=17 pageno[1]=17 pageno[2]=17 pageno[3]=16 pageno[4]=25 pageno[5]=14 pageno[6]=14 pageno[7]=9………………pageno[252]=24 pageno[253]=20 pageno[254]=20 pageno[255]=20vmsize=32k pagesize=1k------------- --------------page assigned pages_in/total references4 7.031250000000000E-16 7.578125000000000E-18 8.085937500000000E-110 8.554687500000000E-112 8.945312500000000E-114 9.140625000000000E-116 9.140625000000000E-118 9.140625000000000E-120 9.140625000000000E-122 9.140625000000000E-124 9.140625000000000E-126 9.140625000000000E-128 9.140625000000000E-130 9.140625000000000E-132 9.140625000000000E-1PAGE NUMBER WITH SIZE 2k EACH ADDRESS IS:………………PAGE NUMBER WITH SIZE 4k EACH ADDRESS IS:………………PAGE NUMBER WITH SIZE 8k EACH ADDRESS IS:………………End the result for opt** **********************************************the algorithm is lru………………同上End the result for lru*********************************************(2)示例中使用的有关数据结构、常量和变量说明如下:length 被调试的指令地址流长度,可作为一个常量设定。
called当前请求的页面号。
pagefault页面失效标志,如当前请求页called已在页表内,则置pagefault=false,否则为true。
table 页表。
table[i]=j,表示虚存的第j页在实存的第i页中。
used当前被占用的实存页面数,可用来判断当前实存中是否有空闲页。
(3)本程序启动后,屏幕上显示“the algorithm is:”,用户可选择最佳淘汰算法(打入“OPT”)或者最近最少使用淘汰算法(打入“LRU”) 计算页面命中率。
当然还可以加入各种其他的算法。
三、实习题(1)编制和调试示例给出的请求页式存储管理程序,并使其投入运行。
(2)增加1~2种已学过的淘汰算法,计算它们的页面访问命中率。
试用各种算法的命中率加以比较分析。
提示:可选用FIFO方法,即先访问的页先淘汰,也可选用LRU方法中的其他方案。
如在页表中设置标志位,按标志位值得变化来淘汰。
也可用LFU方法,为页表中各页面设置访问计数器,淘汰访问频率最低的页(注意:当前访问的页不能淘汰)等等。
实验步骤与源程序#include "iostream"#include "stdio.h"#include "stdlib.h"using namespace std;#define Max 30 //某进程调入内存中的最大页面数#define Size 10 //系统为某进程分配的最大物理块数void Init(int Block[],int m)//初始化物理块{ int i;for(i=0;i<m;i++){Block[i]=-1;}}void creat(int Page[],int n)//输入页面串引用号{ int i;for(i=0;i<n;i++){cin>>Page[i];}}void Init1(int Block1[],int m1){ int i;for(i=0;i<m1;i++){Block1[i]=-1;}}void creat1(int Page[],int n1){ int i;for(i=0;i<n1;i++){Page[i];}}void LRU(int Page[],int Block1[],int n1,int m1){int i,j,max_stay=0,count=0;int get=-1,flag=-1,block_num=-1;int time[Size];for(i=0;i<m1;i++)//初始化time[]{time[i]=0;}for(i=0;i<n1;i++){ for(j=0;j<m1;j++)//有空闲物理块时,页面直接驻入内存空闲块{ if(Block1[j]==-1){get=j; //物理块j即将(/等待)驻入新页面break;}}for(j=0;j<m1;j++) //查找序号相同的页面{if(Block1[j]==Page[i])//物理块j中页面与当前期望调入内存的页面相同{time[j]=0;flag=j;break;}}for(j=0;j<m1;j++) //找到驻留内存时间最久的页面置换出{if(time[j]>max_stay){max_stay=time[j];block_num=j; //block_num标记当前序号物理块中页面驻留时间最久}}if(flag==-1) //不存在相同页面{ if(get!=-1) //物理块即将(/等待)驻入新页面{Block1[get]=Page[i]; //存入页面time[get]=0; //当前物理块重新计时for(j=0;j<=get;j++) //已驻入页面的驻留时间加1{time[j]++;}get=-1;}else //页面调度置换,序号block_num的物理块是驻留时间最久的{Block1[block_num]=Page[i];time[block_num]=0;for(j=0;j<Size;j++){time[j]++;}block_num=-1;max_stay=0;count++;}}else //待调入页面与序号flag的物理块中页面相同{for(j=0;j<m1;j++){time[j]++;}flag=-1;}for(j=0;j<m1;j++)//输出物理块中的页面驻入情况{cout<<" "<<Block1[j];}cout<<endl;}if(n1>m1)count=count+m1;cout<<"缺页中断次数为:"<<count<<endl;}void FIFO(int Page[],int Block[],int n,int m) {int i,j,max_stay=0,count=0;int get=-1,flag=-1,block_num=-1;int time[Size];for(i=0;i<m;i++){ time[i]=0;}for(i=0;i<n;i++){ for(j=0;j<m;j++){ if(Block[j]==-1){get=j;break;}}for(j=0;j<m;j++){ if(Block[j]==Page[i]){flag=j;break;}}for(j=0;j<m;j++){if(time[j]>max_stay){max_stay=time[j];block_num=j;}}if(flag==-1){ if(get!=-1){Block[get]=Page[i];time[get]=0;for(j=0;j<=get;j++){time[j]++;}get=-1;}else{Block[block_num]=Page[i];time[block_num]=0;for(j=0;j<Size;j++){time[j]++;}block_num=-1;max_stay=0;count++;}}else{for(j=0;j<m;j++){time[j]++;}flag=-1;}for(j=0;j<m;j++){cout<<" "<<Block[j];}cout<<endl;}if(n>m)count=count+m;cout<<"缺页中断次数为:"<<count<<endl;}void menu(){cout<<"-------1.LRU页面置换算法--------"<<endl;cout<<"-------2.FIFO 页面置换算法------"<<endl;cout<<"-------3.退出------"<<endl;cout<<"-------默认:-1表示物理块空闲-------"<<endl;cout<<"请选择算法"<<endl;}void main(){ int n,m,Page[Max],Block[Size],n1,m1,Block1[Size]; char t;cout<<endl<<"请输入系统为进程分配的物理块数m<=10:"; cin>>m;m1=m;Init(Block,m);Init1(Block1,m1);cout<<"请输入总页面数n<=30:";cin>>n;n1=n;cout<<"\n请输入页面号引用串:";creat(Page,n);creat1(Page,n1);while(1){menu();cin>>t;switch(t){case '1':LRU(Page,Block1,n1,m1);continue;case '2':FIFO(Page,Block,n,m);continue;case '3':exit(0);}}}测试数据与实验结果图1 输入要分配的物理块数、页面总数、页面序列号图2 LRU算法的实现图3 FIFO算法的实现4、小结(1)编制评测各种算法性能的模拟程序是研制系统程序,尤其是操作系统所必须的。