实验五 存储管理
实习五 虚拟存储器实验报告
实习五虚拟存储器实验报告一、实验目的本次虚拟存储器实验旨在深入理解计算机系统中虚拟存储器的工作原理和机制,通过实际操作和观察,掌握虚拟存储器的相关概念和技术,包括页式存储管理、地址转换、页面置换算法等。
同时,培养我们的实践能力和问题解决能力,为今后学习和工作中涉及到的计算机系统相关知识打下坚实的基础。
二、实验环境本次实验使用的操作系统为 Windows 10,开发工具为 Visual Studio 2019,编程语言为 C++。
三、实验原理1、虚拟存储器的概念虚拟存储器是一种利用硬盘等辅助存储器来扩充主存容量的技术。
它将程序和数据按照一定的页面大小划分,并在需要时将页面从硬盘调入主存,从而实现了使用有限的主存空间运行较大规模的程序。
2、页式存储管理页式存储管理将主存和辅存空间都划分为固定大小的页面。
程序的地址空间被分成若干页,主存也被分成相同大小的页框。
通过页表来记录页面和页框的对应关系,实现地址转换。
3、地址转换当 CPU 执行指令时,给出的是逻辑地址。
通过页表将逻辑地址转换为物理地址,才能在主存中访问相应的数据。
4、页面置换算法当主存空间不足时,需要选择一个页面换出到硬盘,以腾出空间调入新的页面。
常见的页面置换算法有先进先出(FIFO)算法、最近最少使用(LRU)算法等。
四、实验内容与步骤1、设计并实现一个简单的页式存储管理系统定义页面大小和主存、辅存的容量。
实现页表的数据结构,用于记录页面和页框的对应关系。
编写地址转换函数,将逻辑地址转换为物理地址。
2、实现页面置换算法分别实现 FIFO 和 LRU 页面置换算法。
在页面调入和调出时,根据相应的算法选择置换的页面。
3、测试和分析实验结果生成一系列的访问序列,模拟程序的运行。
统计不同页面置换算法下的缺页次数和命中率。
分析实验结果,比较不同算法的性能。
五、实验过程与结果1、页式存储管理系统的实现我们将页面大小设置为 4KB,主存容量为 16MB,辅存容量为 1GB。
样品存储管理制度
样品存储管理制度一、目的和范围为了确保样品的安全和完整性,保证实验结果的可靠性,制定样品存储管理制度。
本制度适用于所有实验室的样品存储管理工作。
二、定义1. 样品:指实验室用于实验分析的各种物质,包括但不限于化学试剂、生物样本、药品等。
2. 样品储存:指将实验室使用的样品进行储存和保管的过程。
3. 样品储存条件:指样品存储的环境、温度、湿度等条件。
三、职责1. 实验室负责人:负责样品储存管理工作的组织和领导,制定并落实样品储存管理制度,确保样品储存的安全和完整性。
2. 实验室管理员:负责样品的接收、储存和发放工作,确保样品储存的合理性和可靠性。
3. 实验人员:负责按照实验室的样品存储管理制度规定进行样品储存和保管,对所使用的样品负责。
四、样品储存管理制度1. 样品接收和登记(1)当收到新的样品时,实验室管理员应及时将样品接收登记,并按照要求储存样品。
(2)样品应在登记簿上进行详细记录,包括样品名称、数量、来源、接收时间等信息。
2. 样品储存区域(1)实验室应设立专门的样品储存区域,保持整洁、通风、干燥,并保持适当的温湿度。
(2)不同类型的样品应储存在不同的储存区域,避免发生交叉污染或混淆。
(3)应根据样品的性质和要求对储存区域进行标识和分类管理。
3. 样品储存条件(1)化学试剂和药品应储存在阴凉、干燥、通风良好的环境中,避免阳光直射或潮湿。
(2)生物样本应储存在低温环境中,避免腐败和变质。
(3)各种样品的储存条件应根据其性质和要求进行规范化管理。
4. 样品标识和分装(1)样品应在接收后进行标识,包括样品名称、接收日期、有效期限等信息。
(2)需要分装的样品应按照规定的程序进行分装,并进行相应的标识,确保可追溯。
5. 样品保管(1)储存的样品应按照规定的程序和要求进行保管,避免因摆放不当导致的样品损坏或丢失。
(2)储存的样品应定期检查,发现问题及时处理,确保储存的样品安全和完整性。
6. 样品发放和使用(1)当实验人员需要使用存储的样品时,应按照规定的程序进行申请和发放,确保样品的流通可控。
数据库课程实验报告_实验五_学生、选课、成绩简易管理系统
实验五编程实施学生、选课、成绩简易管理系统一.目的与要求1.通过编程扩展“学生选课系统”的功能。
2.进一步掌握调试程序的基本步骤和方法。
二.实验内容1.使学生、教师和课程表具有增加、修改、删除和查询数据的功能。
2.学生根据开设的课程进行选课.3.教师根据学生所选课程进行成绩登录。
4.各类统计分析,比如平均成绩。
系统说明:学生:可以进行选课、退课、查分、查看学生自己的信息、修改自己的密码。
教师:可以查询已选学生、登分、查看教师自己的信息、修改自己的密码。
管理员:可以增加和删除课程、学生、教师等信息,可以查看和修改学生、教师密码,可以注册和注消学生、教师,有所有学生的功能,能够查询教师信息。
部分窗口如下:部分代码如下:如查分代码如下:通过datawindow中通过学号可以查看自己成绩。
dw_1.reset()dw_1.settransobject(SQLCA)dw_1.retrieve(user)dw_1.object.datawindow.readonly="yes"三.上机体会。
进一步掌握了开发管理系统的基本方法;掌握了使用PowerBuilder开发环境提供的工具建立应用程序的步骤和方法;掌握应用PowerBuilder提供的调试程序进行应用程序的调试。
实验六SQL Server 2000高级技术的使用一.目的与要求1.练习存储过程的建立和使用。
2.学会触发器的使用。
二.实验内容1.存储过程的建立和使用。
(1)创建存储过程,使其具有如下功能:根据所提供的学号参数,返回该学生的学习情况信息。
(2)查看和修改存储过程;(3)使用存储过程;(4)删除存储过程。
2.触发器的建立和使用(1)创建两个触发器,分别具有如下功能:a.将删除的学生选课信息转移到存档学生选课表中;b.在修改学生成绩时,要求修改后的成绩一定要比原来的成绩高;(2)查看和修改触发器;(3)使用触发器;(4)删除触发器;3.为实验五设计存储过程和触发器,通过调试验证其正确性。
临床试验文件归档与保存操作规程
临床试验文件归档与保存操作规程一、目的为规范临床试验文件的归档与保存工作,保证试验数据的完整性、可追溯性和安全性,制定本操作规程。
二、适用范围本操作规程适用于所有参与临床试验的人员。
三、文件归档要求1.试验文件包括但不限于试验计划、知情同意书、病例报告表、实验数据、质量控制记录等。
2.试验文件的归档应按照试验进度和试验阶段进行,确保文件的顺序和完整性。
3.对于重要的试验文件,应进行电子存档和纸质备份,确保数据的安全性和可追溯性。
四、文件保存时间1.临床试验结束后,试验文件应保存至少十年。
2.根据相关法规和机构要求,部分试验文件可能需要保存更长时间。
3.对于试验文件的注销与销毁,应按照相关法规和机构要求进行,确保数据的安全性和隐私保护。
五、文件归档和保存的责任1.试验执行者应负责组织、整理试验文件,并按照要求进行归档和存储。
2.质量保证部门应对试验文件的归档和保存进行监督和审核,确保文件的完整性和准确性。
3.文件管理部门应负责试验文件的存储和维护,并建立相应的存档系统。
六、文件归档和保存的流程1.归档前,试验执行者应根据试验阶段和试验文件类型进行分类整理,确保文件的顺序和完整性。
2.归档时,试验执行者应将试验文件按照试验进度和试验阶段进行归档,并填写相应的归档记录表。
3.归档记录表应包括文件名称、文件类型、归档时间、归档位置等信息。
4.归档后,试验执行者应将文件交予文件管理部门,进行存储和维护,并填写相应的交接记录表。
七、文件查阅和提取1.试验执行者和相关人员有权查阅和提取试验文件,但需经过审批和记录。
2.查阅和提取试验文件时,应填写相应的查阅和提取记录表,并保证文件的安全性和完整性。
八、文件注销和销毁1.对于不再需要保留的试验文件,应进行注销和销毁。
2.文件注销和销毁应按照相关法规和机构要求进行,并填写相应的注销和销毁记录表。
3.对于涉及隐私信息的试验文件,应采取相应的措施进行安全销毁,确保隐私保护。
实验5数据库的安全性控制(含答案)
实验五数据库的安全性控制一、实验目的:1. 通过实验加深对数据安全性的理解,并掌握SQL Server中有关用户登录的认证以及管理办法;2. 通过实验加深对数据库存储控制机制的理解,通过自主存取控制进行权限管理,熟悉SQL Server中角色管理;3.通过实验加深对数据安全性的理解,熟悉视图机制在自主存取控制上的应用。
二、实验内容1.设置SQL Server的混合安全认证模式。
在SQL Server中的对象资源管理器中设置安全认证模式。
2.在SQL Server中,利用“对象资源管理器”创建一个名为“U1”的登录用户和数据库用户,密码为111,并允许其登录S-T数据库。
3.在SQL Server中,利用代码创建一个名为“U2”的登录用户,密码为111;其相应的数据库用户名为lucky,并允许其登录S-T数据库。
4.用“u1”用户名登录后,执行对students表的查询操作,说明执行结果,并分析原因(建议:在启动一个SQL Server 2008窗口)。
分析:没有对u1进行其他操作的授权,只能登录而不能进行插入,修改等操作5.将students表的操作权限select和insert赋予数据库用户u1,并允许其向其它用户授权。
6.以“u1”用户名登录,执行对students和teacher表的查询操作,将该运行结果进行分析。
分析:对比第4题,对U1进行授权后可以进行相应的操作7.执行下列代码后,分析用户u2能否对s_t数据库的student表进行select 和update操作,为什么?并用相应的语句验证。
分析:首先grant给public组赋予了查询,插入,更新权限,然后给lucky用户赋予了对S表的所有权限,然后又revoke收回了lucky的权限,但并没有收回public组的权限,而deny却收回了lucky的更新权限,故查询可实现,而更新不可实现8.以sa登录数据库,在s_t数据库的stc表上创建选修了课程B001的视图st_view。
答案_实验五 存储管理(二)
实验五存储管理(二)学号:姓名:班级:实验目的:1. 了解虚拟存储器。
2. 掌握分页存储管理的原理,熟悉段式存储和段页式存储管理。
3. 掌握常用的页面置换算法。
实验内容:一、选择:1.可变分区方式常用的主存分配算法中,(C)总是找到能满足作业要求的最大空闲区分配A、最佳适应算法B、首次适应算法C、最坏适应算法D、循环首次适应算法2.下列(A )存储方式不能实现虚拟存储器A、分区B、页式C、段式D、段页式3.操作系统处理缺页中断时,选择一种好的调度算法对主存和辅存中的信息进行高效调度尽可能地避免(D)A、碎片B、CPU空闲C、多重中断D、抖动4.分页式存储管理的主要特点是(C)A、要求处理缺页中断B、要求扩充主存容量C、不要求作业装入到主存的连续区域D、不要求作业全部同时装人主存5.LRU页面调度算法淘汰(B)的页A、最近最少使用B、最近最久未使用C、最先进入主存D、将来最久使用6.分区管理要求对每一个作业都分配(A)的主存单元A、地址连续B、若干地址不连续的C、若干连续的页D、若干不连续的帧7.在存储管理中,采用覆盖与交换技术的目的是(A)A、节省主存空间B、物理上扩充主存容量C、提高CPU的效率D、实现主存共享8.分页虚拟存储管理中,缺页中断时,欲调度一页进入主存中,内存己无空闲块,如何决定淘汰已在主存的块时,(B)的选择是很重要的A、地址变换B、页面调度算法C、对换方式D、覆盖技术9.(D)存储管理兼顾了段式在逻辑上清晰和页式在存储管理上方便的优点A、分段B、分页C、可变分区方式D、段页式10.在固定分区分配中,每个分区的大小是(C)A、随作业长度变化B、相同C、可以不同但预先固定D、可以不同但根据作业长度固定11.下述(B)页面置换算法会产生Belady现象A、最佳置换算法B、先进先出算法C、LRU算法D、Clock算法12.在一个分页式存储管理系统中,页表的内容为:若页的大小为4KB,则地址转换机构将相对地址0转换成的物理地址是(A)。
学校实验室危险有害物质“五双”管理制度
学校实验室危险有害物质“五双”管理制度一、定义实验室危险有害物质是指对人体健康或环境有潜在危害的化学物质、生物剂、放射性物质等。
根据其危险特性和使用需要,将其划分为以下五对(“五双”):1. 高毒害性和有爆炸性的物质:包括但不限于有毒化学品、爆炸物等。
高毒害性和有爆炸性的物质:包括但不限于有毒化学品、爆炸物等。
2. 易燃易爆性物质:包括但不限于易燃化学品、易燃气体等。
易燃易爆性物质:包括但不限于易燃化学品、易燃气体等。
3. 强腐蚀性物质:包括但不限于酸、碱等。
强腐蚀性物质:包括但不限于酸、碱等。
4. 有害有毒气体:包括但不限于有毒气体、有害气体等。
有害有毒气体:包括但不限于有毒气体、有害气体等。
5. 放射性物质和生物致病性物质:包括但不限于放射性元素、病原菌等。
放射性物质和生物致病性物质:包括但不限于放射性元素、病原菌等。
二、管理措施为确保实验室危险有害物质的安全管理,学校制定了以下“五双”管理措施:1. 采购管理:在采购实验室危险有害物质时,必须遵循严格的采购程序和标准。
相关人员应了解物质的危险性,选择符合安全要求的物质,并与供应商建立合作关系,确保物质的质量和供应。
采购管理:在采购实验室危险有害物质时,必须遵循严格的采购程序和标准。
相关人员应了解物质的危险性,选择符合安全要求的物质,并与供应商建立合作关系,确保物质的质量和供应。
2. 存储管理:学校实验室应设立专门的危险有害物质存储区域。
存储区域应符合相关安全要求,采取防火、防腐蚀、防泄漏等措施,避免物质的损坏和泄漏。
实验室人员应按照分类、标记、包装等要求,将物质妥善存放,并进行定期检查和清理。
存储管理:学校实验室应设立专门的危险有害物质存储区域。
存储区域应符合相关安全要求,采取防火、防腐蚀、防泄漏等措施,避免物质的损坏和泄漏。
实验室人员应按照分类、标记、包装等要求,将物质妥善存放,并进行定期检查和清理。
3. 使用管理:实验室人员在使用危险有害物质时,必须遵循操作规程和标准操作程序。
实验五DAM to SDRAM例程详解
一、实验目的:1. 熟悉Visual DSP软件。
2. 了解Blankfin系列DSP芯片的内存管理情况以及DMA寄存器的配置和基于描述符的DMA 传送机制二、实验要求:例程详解:visual 4.5版本的安装目录下,找exzmple/blackfin535/DMA to SDRAM 的文件,写一份例程详解报告。
三、实验分析:1. 相关知识⑴DMABlackfin使用 DMA进行存储器空间内部或者存储器空间与外设之间的数据传送.DMA控制器允许Blackfin或外部设备指定数据传送操作,然后其返回到正常操作中。
DMA控制器传送数据的过程独立于处理器的活动。
DMA控制器将数据传输完成后会给处理器内核一个信号来表示数据已经传完。
⑵SDRAM同步DRAM。
其工作频率与系统工作频率相同。
⑶内存管理21535的内存管理把存储器视为一个统一的4GB的地址空间,使用32位地址。
所有的资源,包括内部存储器、外部存储器、PCI地址空间和I/O控制寄存器,都具有独立的地址空间。
芯片内部的308KB RAM中,L1(一级缓存)52KB,L2(二级缓存)256KB (0xF003FFFF~~0xF000000);内存地址的具体配置空间如下图所示.L1 内存访问速度最快,每个处理器周期能完成一次访问。
L2 内存远离内核处理器,用于存储更大量的程序代码和数据。
存储器的DMA控制器提供高带宽的数据传输能力,它能够在内部L1/L2存储器和外部存储器(包括PCI存储空间)之间执行代码或者数据的块传输。
⑷ DMA寄存器的配置为了描述Mem DMA序列,DMA控制器使用一套名为描述子块(Descriptor)的参数。
当需要后继的DMA序列时,这些描述子块被链接起来。
这样,一个DMA序列完成时能够自动初始化下一个序列,并将其启动。
如果不需启动下一个序列,只要将其指向一个内容为0的地址空间即可。
如果下一次链接指向原描述子块,则DMA完成后暂停。
实验五 存储过程和触发器的使用
实验五存储过程和触发器的使用【目的要求】1、了解存储过程的基本概念和类型。
2、了解创建存储过程的T-SQL语句的基本语法。
3、了解查看、执行、修改和删除存储过程的T-SQL命令的用法。
4、了解触发器的基本概念和类型。
5、了解创建触发器的T-SQL语句的基本语法。
6、了解查看、修改和删除存储过程的T-SQL命令的用法。
【实验内容】内容一:存储过程的使用一、数据需求分析存储过程是一种数据库对象,为了实现某个特定任务,将一组预编译的SQL语句以一个存储单元的形式存储在服务器上,供用户调用,自动完成需要预先执行的任务。
存储过程在第一次执行时进行编译,然后将编译好的代码保存在高速缓存中便于以后调用,提高了代码的执行效率。
二、内容要点分析1、SQL SERVER支持五种类型的存储过程:系统存储过程、本地存储过程、临时存储过程、远程存储过程和扩展存储过程。
其中,系统存储过程是由系统提供的存储过程,可以作为命令执行各种操作。
系统存储过程定义在系统数据库master中,其前缀是sp_。
本地存储过程是指在用户数据库中创建的存储过程,这种存储过程完成特定数据库操作任务,不能以sp_为前缀。
2、只能在当前数据库中创建存储过程。
3、创建存储过程时,应指定所有输入参数和向调用过程或批处理返回的输出参数、执行数据库操作的编程语句和返回至调用过程或批处理以表明成功或失败的状态值。
4、创建存储过程的T-SQL语句CREATE PROC[EDURE] 存储过程名称[{ @参数名称数据类型 }] [,…n][WITH{ RECOMPILE|ENCRYPTION }]ASSQL语句序列说明:(1)RECOMPILE表明每次运行该过程时,将其重新编译。
(2)ENCRYPTION表示 SQL SERVER 加密SYSCOMMENTS表中包含CREATE PROCEDURE语句文本的条目。
注:必须将CREATE PROCEDURE语句放在单个批处理中。
实验五-动态分区存储管理
实验五动态分区存储管理一、实验目的深入了解采用动态分区存储管理方式的内存分配回收的实现。
通过编写和调试存储管理的模拟程序以加深对存储管理方案的理解,熟悉动态分区存储管理的内存分配和回收。
二、实验内容编写程序完成动态分区存储管理方式的内存分配回收。
具体包括:确定内存空间分配表;采用最优适应算法完成内存空间的分配和回收;编写主函数对所做工作进行测试。
三、设计思路整体思路:动态分区管理方式将内存除操作系统占用区域外的空间看成一个大的空闲区。
当作业要求装入内存时,根据作业需要内存空间的大小查询内存中的各个空闲区,当从内存空间中找到一个大于或等于该作业大小的内存空闲区时,选择其中一个空闲区,按作业需求量划出一个分区装人该作业,作业执行完后,其所占的内存分区被收回,成为一个空闲区。
如果该空闲区的相邻分区也是空闲区,则需要将相邻空闲区合并成一个空闲区。
设计所采用的算法:采用最优适应算法,每次为作业分配内存时,总是把既能满足要求、又是最小的空闲分区分配给作业。
但最优适应算法容易出现找到的一个分区可能只比作业所需求的长度略大一点的情行,这时,空闲区分割后剩下的空闲区就很小以致很难再使用,降低了内存的使用率。
为解决此问题,设定一个限值minsize,如果空闲区的大小减去作业需求长度得到的值小于等于minsize,不再将空闲区分成己分分区和空闲区两部分,而是将整个空闲区都分配给作业。
内存分配与回收所使用的结构体:为便于对内存的分配和回收,建立两张表记录内存的使用情况。
一张为记录作业占用分区的“内存分配表”,内容包括分区起始地址、长度、作业名/标志(为0时作为标志位表示空栏目);一张为记录空闲区的“空闲分区表”,内容包括分区起始地址、长度、标志(0表空栏目,1表未分配)。
两张表都采用顺序表形式。
关于分配留下的内存小碎片问题:当要装入一个作业时,从“空闲分区表”中查找标志为“1”(未分配)且满足作业所需内存大小的最小空闲区,若空闲区的大小与作业所需大小的差值小于或等于minsize,把该分区全部分配给作业,并把该空闲区的标志改为“0”(空栏目)。
操作系统实验报告
操作系统实验报告专业:软件工程姓名:李程星学号:2011221104220092实验一操作系统的用户界面LINUX操作系统提供了图形用户界面和命令行界面,本实验主要熟悉命令行界面,为后续的实验编程做准备。
一、系统启动1. 开机,选择进入Linux系统,约40秒后系统启动成功,系统提示输入用户名:user输入口令:111111 然后进入Linux系统桌面。
2.进入Linux命令行方式单击小红帽图标,选择“系统工具”,单击“终端”图标,出现Linux的shell提示符.....@......$,,即可输入命令。
实验二进程管理一、实验目的(1)加深对进程概念的理解,明确进程和程序的区别。
(2)进一步认识并发执行的实质。
二、实验内容1、进程的创建执行下面的程序,分析执行的结果。
#include <stdio.h>main(){ int i;printf("just 1 process.\n");i=fork();if (i==0)printf("I am child.\n");elseif (i>0)printf("I am parent.\n");elseprintf("fork() failed.\n");printf("program end.\n");}输出结果:just 1 process.I am parent.program end.I am a child.program end.2、进程的同步执行下面的程序,分析执行的结果。
#include <stdio.h>main(){ int i;printf("just 1 process.\n");i=fork();if (i>0){printf("I am parent.\n");wait();}elseif (i==0) {printf("I am child.\n");exit(1);}printf("program end.\n");}输出结果:just 1 process.I am parent.I am child.program end.3、进程的延迟执行下面的程序,分析执行的结果。
数据库实验报告:实验五
数据库实验报告:实验五一、实验目的本次数据库实验五的主要目的是深入了解和掌握数据库的高级操作,包括存储过程的创建与使用、视图的定义和应用、以及事务处理的原理和实践。
通过这些实验内容,提高我们对数据库系统的综合运用能力,为解决实际的数据库管理问题打下坚实的基础。
二、实验环境本次实验使用的数据库管理系统是 MySQL 80,开发工具为 Navicat Premium 12。
操作系统为 Windows 10 专业版。
三、实验内容及步骤(一)存储过程的创建与使用1、创建一个名为`get_student_info` 的存储过程,用于根据学生学号查询学生的基本信息(包括学号、姓名、年龄、性别和专业)。
```sqlDELIMITER //CREATE PROCEDURE get_student_info(IN student_id INT)BEGINSELECT FROM students WHERE student_id = student_id;END //DELIMITER ;```2、调用上述存储过程,查询学号为 1001 的学生信息。
```sqlCALL get_student_info(1001);```(二)视图的定义和应用1、创建一个名为`student_grade_view` 的视图,用于显示学生的学号、姓名和平均成绩。
```sqlCREATE VIEW student_grade_view ASSELECT sstudent_id, sname, AVG(ggrade) AS average_gradeFROM students sJOIN grades g ON sstudent_id = gstudent_idGROUP BY sstudent_id, sname;```2、查询上述视图,获取所有学生的平均成绩信息。
```sqlSELECT FROM student_grade_view;```(三)事务处理1、开启一个事务,向学生表中插入一条新的学生记录(学号:1005,姓名:_____,年龄:20,性别:男,专业:计算机科学)。
实验五 数据库应用程序的设计
idcard varchar(15),
realname varchar(32) not null,
username varchar(32) not null,
sex char(2)
能。
二、实验任务
设计、开发一个简单的管理信息系统(如人设计人力资源管理系统的功能结构。
2. 使用SL Server 2000数据库管理系统创建和管理该系统的后台数据库。
3. 使用Delphi编程语言(也可自选其他编程语言)进行该系统前台的开发。
四、注意事项
1)各模块功能的实现。
2)实验报告主要包括数据库的设计部分
五、实验学时:4学时(未完成部分在课下完成)
六、实验重点及难点
1. 系统功能结构的设计。
2. 数据库结构的设计。
3. 各模块界面的设计和功能的实现。
4. 尝试采用存储过程来实现所有对数据库的操作(包括查询、修改、增加、删除)
七、实验步骤
1. 存储过程及触发器
(1)建立Employees,department表,对该表中的departmentID列建立索引;对birthday按降序,marriage按升序建立索引;对idcard建立唯一索引
create table Employees(
staffid varchar(8) primary key ,
请求页式存储管理的页面置换算法.
《操作系统》实验报告班级:计科0801班姓名:边佳学号:08407102 日期:2011年5月19日实验五请求页式存储管理的页面置换算法实验目的:通过请求页式存储管理中页面置换算法模拟程序,了解虚拟存储技术的特点,掌握请求页式存储管理的页面置换算法。
实验属性:设计实验内容:1.通过随机数产生一个指令序列,共320条指令,指令的地址按下述原则生产:50%的指令是顺序执行的;25%的指令是均匀分布在前地址部分;25%的指令是均匀分布在后地址部分。
2.将指令序列变换成为页地址流:设页面大小为1K;用户内存容量为4页到32页;用户虚存容量为32K。
在用户虚存中,按每K存放10条指令排列虚存地址,即320条指令在虚存中的存放方式为:第0条至第9条指令为第0页;第10条至19条指令为第1页;…第310条至319条指令为第31页。
3.计算并输出下述各种算法在不同内存容量下的命中率。
(1 先进先出算法(FIFO)(2 最近最少使用算法(LRU)(3 最佳使用算(OPT)命中率=1-页面失效次数/页地址流长度本实验中,页地址流长度为320,页面失效次数为每次访问相应指令时,该指令所对应的页不在内存的次数。
实验思路:关于随机数的产生办法,首先要初始化设置随机数,产生序列的开始点,可通过下列语句实现: srand ( 400 ;(1 计算随机数,产生320条指令序列m=160;for (i=0;i<80;i++={j=i﹡4;a[j]=m;a[j+1]=m+1;a[j+2]=a[j] ﹡1.0﹡ rand( /32767;a[j+3]=a[j+2]+1m=a[j+3]+(319-a[j+3] ﹡1.0﹡rand( /32767;}(2 将指令序列变换成为页地址流for ( k=0;k<320;k++{ pt=a[k]/10;pd= a[k]%10;…}(3 计算不同算法的命中率rate=1-1.0﹡U/320 ;其中U为缺页中断次数,320是页地址流长度。
操作系统实验五 指导书
实验五 Windows XP 虚拟内存管理一实验目的1) 了解存储器管理以及虚拟存储器管理的基本原理2)了解和学习Windows系统管理工具中关于内存管理的设置和使用;二实验环境需要准备一台运行Windows XP操作系统的计算机。
三背景知识虚拟存储器技术是当代计算机中广泛采用的内存管理方案,在Windows XP中合理的进行虚拟内存的设置,可以更有效的提高系统的工作效率。
利用系统自带的系统监视器可以查看虚拟内存的使用情况,根据使用情况可以灵活的进行虚拟内存的管理。
四实验内容与步骤启动并进入Windows环境,单击Ctrl + Alt + Del键,或者右键单击任务栏,在快捷菜单中单击“任务管理器”命令,打开“任务管理器”窗口。
步骤1:当前机器中由你打开,正在运行的应用程序有: WPS 文字 - [实验五指导书.doc]步骤2:单击“进程”选项卡,一共显示了个进程。
请试着区分一下,其中:系统 (SYSTEM) 进程有个,分别填入表2-1中。
表2-1 实验记录映像名称用户名CPU使用率内存使用进程实现的功能服务 (SERVICE) 进程有个,填入表2-2中。
表2-2 实验记录映像名称用户名CPU使用率内存使用进程实现的功能用户进程有个,填入表2-3中。
表2-3 实验记录映像名称用户名CPU使用率内存使用进程实现的功能步骤3:点击任务管理器中性能标签,查看本机的物理内存容量为 k,再查看一下,物理内存可用数 k,核心内存总数 k,核心内存为操作系统所占的内存,可将以上表格中所填写的各进程所占内存数与步骤3中填写的数字做下比较,比较的结果是。
步骤4:用鼠标右键点击“我的电脑”,选择“属性”,弹出系统属性窗口,选择“高级”标签,点击“性能”下面的“设置”按钮,再选择高级标签,查看本机的虚拟内存大小为 M,点击更改按钮,本系统所用的虚拟内存设置在分区,初始大小 M,最大值 M,当前已分配 M,页面大小 M。
实验五 matlab基础知识(简单)
本次实验注意:《实验五MALTAB基础知识(简单)》《实验五基于Matlab的信号频谱分析(复杂)》选作一个即可实验五MALTAB基础知识(一)实验目的 (2)(二)实验设备 (2)(三)实验要求 (2)(四)实验内容 (2)1.1 MATLAB基础知识 (2)1.1.1 MATLAB程序设计语言简介 (2)1.1.2 MA TLAB界面及帮助 (2)1.2 MA TLAB基本运算 (4)1.2.1 MA TLAB内部特殊变量和常数 (4)1.2.2 变量类型 (4)1.2.3 内存变量管理 (5)1.2.4 MA TLAB常用数学函数 (5)1.2.5 MA TLAB矩阵生成 (5)1.2.6 MA TLAB矩阵运算 (8)1.2.7 MA TLAB中的矩阵分析 (10)1.3 MA TLAB程序设计 (10)1.3.1 M文件 (10)1.3.2 程序控制结构 (12)实验五MALTAB基础知识(一)实验目的●了解MA TLAB 程序设计语言的基本特点,熟悉MA TLAB软件运行环境●掌握创建、保存、打开m文件及函数的方法●掌握变量等有关概念,具备初步的将一般数学问题转化为对应的计算机模型并进行处理的能力(二)实验设备计算机,Matlab软件(三)实验要求本实验属于验证实验,请根据(四)实验内容的步骤,运行相应的指令或例子,并将仿真结果截图至文档(请自己新建一个word文档,注意,并不一定所有指令或例子的实验结果都要截图,截图数目大于等于5个即可,自己选择性截图,答案不唯一,自由发挥)请在页眉处填写班级、学号、姓名,并将实验报告命名为“实验五_学号_姓名”,并通过FTP上传至指定文件夹。
(四)实验内容1.1 MATLAB基础知识1.1.1 MATLAB程序设计语言简介MA TLAB,Matrix Laboratory的缩写,是由MathWorks公司开发的一套用于科学工程计算的可视化高性能语言,具有强大的矩阵运算能力。
操作系统实验五虚拟存储器管理
操作系统实验实验五虚拟存储器管理学号 1115102015 姓名方茹班级 11电子A 华侨大学电子工程系实验五虚拟存储器管理实验目的1、理解虚拟存储器概念。
2、掌握分页式存储管理地址转换盒缺页中断。
实验内容与基本要求1、模拟分页式存储管理中硬件的地址转换和产生缺页中断。
分页式虚拟存储系统是把作业信息的副本存放在磁盘上,当作业被选中时,可把作业的开始几页先装入主存且启动执行。
为此,在为作业建立页表时,应说明哪些页已在主存,哪些页尚未装入主存。
作业执行时,指令中的逻辑地址指出了参加运算的操作存放的页号和单元号,硬件的地址转换机构按页号查页表,若该页对应标志为“1”,则表示该页已在主存,这时根据关系式“绝对地址=块号×块长+单元号”计算出欲访问的主存单元地址。
如果块长为2 的幂次,则可把块号作为高地址部分,把单元号作为低地址部分,两者拼接而成绝对地址。
若访问的页对应标志为“0”,则表示该页不在主存,这时硬件发“缺页中断”信号,有操作系统按该页在磁盘上的位置,把该页信息从磁盘读出装入主存后再重新执行这条指令。
设计一个“地址转换”程序来模拟硬件的地址转换工作。
当访问的页在主存时,则形成绝对地址,但不去模拟指令的执行,而用输出转换后的地址来代替一条指令的执行。
当访问的页不在主存时,则输出“* 该页页号”,表示产生了一次缺页中断。
2、用先进先出页面调度算法处理缺页中断。
FIFO 页面调度算法总是淘汰该作业中最先进入主存的那一页,因此可以用一个数组来表示该作业已在主存的页面。
假定作业被选中时,把开始的m 个页面装入主存,则数组的元素可定为m 个。
实验报告内容1、分页式存储管理和先进先出页面调度算法原理。
分页式存储管理的基本思想是把内存空间分成大小相等、位置固定的若干个小分区,每个小分区称为一个存储块,简称块,并依次编号为0,1,2,3,……,n块,每个存储块的大小由不同的系统决定,一般为2的n次幂,如1KB,2 KB,4 KB等,一般不超过4 KB。
SQL实验五 创建与管理数据库
实验五创建与管理数据库一、实验内容1.创建名为Sale的销售数据库。
该数据库有一一个名为Sale mdf的主数据文件和名为Sale_ log.ldf的事务日志文件。
主数据文件容量为4MB,事务日志文件容量为10MB,数据文件和事务日志文件的最大容量为20MB,文件增长量为1MB。
USEmasterGOCREATEDATABASE SaleONPRIMARY(NAME = Sale,FILENAME='E:\Sale.mdf',SIZE = 5MB,MAXSIZE = 20MB,FILEGROWTH = 1MB)LOG ON(NAME =Sale_log,FILENAME='E:\Sale_log.ldf',SIZE = 10MB,MAXSIZE = 20MB,FILEGROWTH = 1MB)GO2.在Sale数据库下新增名字为UserGroup的文件组。
USE SaleGOalterdatabase Saleaddfilegroup UserGroupgo查看Sale数据库中的文件USE SaleGOSP_helpfilegroupgo3.以增加次数据文件的方式扩充Sale数据库的容量。
次数据文件容量为5MB,最大容量为10MB,文件增量为1MB。
要求将次数据文件保存在与事务日志文件不同的存储设备_上,次数据文件作为UserGroup文件组的成员。
usemastergoalterdatabase Saleaddfile(name=sale2,filename='D:\sale2.ndf',size=5MB,maxsize=10MB,filegrowth=1MB)tofilegroup UserGroupgo查看Sale数据库中的文件USE SaleGOSP_helpfilegroupgo。
校园实验室高危物质“五双”管理规定
校园实验室高危物质“五双”管理规定为了加强校园实验室高危物质的安全管理,保障师生的人身安全和校园的和谐稳定,根据国家有关法律法规和学校实验室安全管理规定,特制定本“五双”管理规定。
一、管理原则1. 预防为主,防治结合。
加强高危物质的安全管理,预防事故的发生,确保实验室安全。
2. 分工负责,责任到人。
明确高危物质管理责任,确保各项工作落实到位。
3. 规范操作,强化培训。
加强对实验室人员的培训,提高其安全意识和操作技能。
二、管理内容1. 存储管理1.1 高危物质必须存放在专用储存柜中,储存柜应具有防火、防盗、防爆等功能。
1.2 储存柜应设置明显的警示标识,标识应包括物质名称、性质、危险等级等信息。
1.3 高危物质应按照性质和危险等级分类存放,不得混合储存。
2. 领取与使用2.1 高危物质的领取必须由经过培训合格的实验室人员操作,领取前需填写《高危物质领取申请表》。
2.2 高危物质的使用应严格按照实验方案和操作规程进行,不得擅自改变用途。
2.3 使用过程中产生的废弃物,应按照《废弃物处理规定》进行分类、收集、存放,定期交由专业处理公司处理。
3. 运输管理3.1 高危物质运输应使用符合安全规定的容器和交通工具,并遵守相关交通法规。
3.2 运输过程中应做好个人防护,防止泄露、溢出等事故的发生。
4. 应急处理4.1 实验室应制定应急预案,明确应急处理流程和责任人。
4.2 实验室人员应定期进行应急演练,提高应对突发事件的能力。
5. 资料管理5.1 实验室应建立健全高危物质管理档案,包括物质清单、存储位置、领取使用记录等信息。
5.2 实验室应定期对管理档案进行审核、更新,确保信息准确、完整。
三、监督管理1. 学校相关部门应加强对实验室高危物质安全管理的监督检查,发现问题及时整改。
2. 实验室应设立安全管理员,负责日常安全管理工作的组织实施和检查。
3. 实验室人员应严格遵守本规定,对违反规定的行为,学校将依法追究责任。
黄天实验五虚拟存储器管理实验报告
实验五虚拟存储器管理学号 1415251011 姓名黄天班级 14集成1班华侨大学电子工程系设计目的1、理解虚拟存储器概念。
2、掌握分页式存储管理地址转换和缺页中断。
设计内容与基本要求1、模拟分页式存储管理中硬件的地址转换和产生缺页中断。
2、用先进先出页面调度算法处理缺页中断。
设计报告内容1、分页式存储管理和先进先出页面调度算法原理。
1).分页式存储管理原理在存储器管理中,连续分配方式会形成许多“碎片”,虽然可通过“紧凑”方法将许多碎片拼接成可用的大块空间,但须为之付出很大开销。
如果允许将一个进程直接分散地装入到许多不相邻的分区中,则无须再进行“紧凑”。
基于这一思想而产生了离散分配方式。
如果离散分配的基本单位是页,则称为分页存储管理方式。
在分页存储管理方式中,如果不具备页面对换功能,则称为基本分页存储管理方式,或称为纯分页存储管理方式,它不具有支持实现虚拟存储器的功能,它要求把每个作业全部装入内存后方能运行。
请求式分页系统是建立在基本分页基础上的,为了能支持虚拟存储器功能,而增加了请求调页功能和页面置换功能。
2).先进先出页面调度算法原理优先淘汰最早进入内存的页面,亦即在内存中驻留时间最久的页面。
该算法实现简单,只需把调入内存的页面根据先后次序链接成队列,设置一个指针总指向最早的页面。
但该算法与进程实际运行时的规律不适应,因为在进程中,有的页面经常被访问。
2、程序流程图LAB5_HT_14152510113、程序及注释。
#include<cstdio>#include<cstring>#define SizeOfPage 100 //定义页面#define SizeOfBlock 128#define M 4struct info//页表信息结构体{bool flag; //页标志,1表示该页已在主存,0表示该页不在主存long block;//块号4、运行结果以及结论。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验五存储管理一、实验目的存储管理的主要功能之一是合理地分配空间。
请求页式管理是一种常用的虚拟存储管理技术。
本实验的目的是通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的技术特点,掌握请求页式存储管理的页面置换算法。
二、实验学时2学时三、实验内容(1)通过随机数产生一个指令序列,共320条指令。
指令的地址按下述原则生成:①50%的指令是顺序执行的;②50%的指令是均匀分布在前地址部分;③50%的指令是均匀分布在后地址部分。
具体的实施方法是:①在 [0,319] 的指令之间随即选取一起点m;②顺序执行一条指令,即执行地址为m+1的指令;③在前地址[0,m+1]中随机选取一条指令并执行,该指令的地址为m′;④顺序执行一条指令,其地址为 m′+ 1;⑤在后地址[m′+ 2,319]中随机选取一条指令并执行;⑥重复上述步骤①-⑤,直到执行320次指令。
(2)将指令序列变换为页地址流设:①页面大小为1k;②用户内存容量为4页到32页;③用户虚存容量为32k。
在用户虚存中,按每k存放10条指令排在虚存地址,即320条指令在虚存中的存放方式为:第0条-第9条指令为第0页(对应虚存地址为[0,9]);第10条-第19条指令为第一页(对应虚存地址为[10,19]);……第310条~第319条指令为第31页(对应虚地址为[310,319])。
按以上方式,用户指令可组成32页。
(3)基于一个虚拟存储区和内存工作区,设计下述算法并计算访问命中率。
1、最佳淘汰算法(OPT)2、先进先出的算法(FIFO)3、最近最久未使用算法(LRU)4、简单时钟(钟表)算法(CLOCK)命中率=1-页面失效次数/页地址流(序列)长度在本实验中,页地址流长度为320,页面失效次数为每次访问相应指令时,该指令所对应的页不在内存的次数。
随机数产生办法Linux或UNIX系统提供函数srand()和rand(),分别进行初始化和产生随机数。
例如:srand ();语句可初始化一个随机数;a[0]=10*rand()/65535*319+1;a[1]=10*rand()/65535*a[0];语句可用来产生a[0]与a[1]中的随机数。
四、实验步骤<程序设计〉本实验的程序设计基本上按照实验内容进行。
即首先用srand()和rand()函数定义和产生指令序列,然后将指令序列变换成相应的页地址流,并针对不同的算法计算出相应的命中率。
相关定义如下:1 数据结构(1)页面类型typedef struct{int pn,pfn,counter,time;}pl-type;其中pn 为页号,pfn为面号, counter为一个周期内访问该页面的次数,time为访问时间.(2) 页面控制结构pfc-struct{int pn,pfn;struct pfc_struct *next;}typedef struct pfc_struct pfc_type;pfc_type pfc_struct[total_vp],*freepf_head,*busypf_head;pfc_type *busypf_tail;其中pfc[total_vp]定义用户进程虚页控制结构,*freepf_head为空页面头的指针,*busypf_head为忙页面头的指针,*busypf_tail为忙页面尾的指针.2.函数定义(1)Void initialize( ):初始化函数,给每个相关的页面赋值.(2)Void FIFO( ):计算使用FIFO算法时的命中率.(3)Void LRU( ):计算使用LRU算法时的命中率.(4)Void OPT( ):计算使用OPT算法时的命中率.(6)Void CLOCK( ):计算使用clock算法时的命中率.3.变量定义(1)int a[total_instruction]: 指令流数据组.(2)int page[total_instruction]: 每条指令所属的页号.(3)int offset[total_instruction]: 每页装入10条指令后取模运算页号偏移值.(4)int total_pf: 用户进程的内存页面数.(5)int disaffect: 页面失效次数.4.程序参考源码及结果<程序>#include<stdio.h>#include<stdlib.h>#include<unistd.h>#include<string.h>#ifndef _UNISTD_H#define _UNISTD_H#include<IO.H>#include<PROCESS.H>#endif#define TRUE 1#define FALSE 0#define INVALID -1#define total_instruction 320 //指令流长#define total_vp 32 //虚页长#define clear_period 50 //清周期typedef struct//页面结构{int pn, //页面序号pfn, //页面所在内存区的帧号counter, //单位时间内访问次数time; //上次访问的时间}pl_type;pl_type pl[total_vp]; //页面结构数组struct pfc_struct{ //页面控制结构int pn, //页面号pfn; //内存区页面的帧号struct pfc_struct *next; //页面指针,用于维护内存缓冲区的链式结构};typedef struct pfc_struct pfc_type; //主存区页面控制结构别名pfc_type pfc[total_vp], //主存区页面控制结构数组*freepf_head, //主存区页面控制结构的空闲页面头指针*busypf_head, //主存区页面控制结构的忙页面头指针*busypf_tail; //主存区页面控制结构的忙页面尾指针int diseffect; //页错误计数器,初次把页面载入主存时也当做页错误int a[total_instruction]; //随即指令流数组int page[total_instruction]; //指令对应的页面号int offset[total_instruction]; //指令所在页面中的偏移量int initialize(int); //初始化页面结构数组和页面控制结构数组int FIFO(int); //先进先出算法int LRU(int); //最近最久未使用算法int OPT(int); //最佳置换算法int CLOCK(int); //简单时钟(钟表)算法int main( ){int s; //随机数int i;srand(10*getpid()); /*每次运行时进程号不同,用来作为初始化随机数队列的"种子"*/s = (int)((float)(total_instruction-1)*(rand()/(RAND_MAX+1.0)));printf("\n------------随机产生指令流------------\n");for (i=0; i<total_instruction; i+=4) //产生指令队列{a[i]=s; //任选一指令访问点ma[i+1]=a[i]+1; //顺序执行一条指令a[i+2]=(int)((float)a[i]*(rand()/(RAND_MAX+1.0))); //执行前地址指令m'a[i+3]=a[i+2]+1; //顺序执行一条指令printf("%6d%6d%6d%6d\n", a[i],a[i+1],a[i+2],a[i+3]);s = (int)((float)((total_instruction-1)-a[i+2])*(rand()/(RAND_MAX+1.0))) + a[i+2]; }printf("--------------------------------------\n");for (i=0;i<total_instruction;i++) //将指令序列变换成页地址流{page[i]=a[i]/10;offset[i]=a[i]%10;}printf("\n--不同页面工作区各种替换策略的命中率表--\n");printf("Page\t FIFO\t LRU\t OPT\t CLOCK\n");for(i=4;i<=32;i++) //用户内存工作区从个页面到个页面{printf(" %2d \t",i);FIFO(i);LRU(i);OPT(i);CLOCK(i);printf("\n");}return 0;}//初始化页面结构数组和页面控制结构数组//total_pf; 用户进程的内存页面数int initialize(int total_pf){int i;diseffect=0;for(i=0;i<total_vp;i++){pl[i].pn=i;pl[i].pfn=INVALID; //置页面所在主存区的帧号为-1.表示该页不在主存中pl[i].counter=0; //置页面结构中的访问次数为pl[i].time=-1; //置页面结构中的上次访问的时间为-1 }for(i=0;i<total_pf-1;i++){pfc[i].next=&pfc[i+1]; //建立pfc[i-1]和pfc[i]之间的链接pfc[i].pfn=i; //初始化主存区页面的帧号}pfc[total_pf-1].next=NULL;pfc[total_pf-1].pfn=total_pf-1;freepf_head=&pfc[0]; //主存区页面控制结构的空闲页面头指针指向pfc[0]return 0;}//最近最久未使用算法//int total_pf; 用户进程的内存页面数int LRU (int total_pf){int MinT; //最小的访问时间,即很久没被访问过int MinPn; //拥有最小的访问时间的页的页号int i,j;int CurrentTime; //系统当前时间initialize(total_pf); //初始化页面结构数组和页面控制结构数组CurrentTime=0;diseffect=0;for(i=0;i<total_instruction;i++){if(pl[page[i]].pfn==INVALID) //页面失效{diseffect++; //页错误次数加if(freepf_head==NULL) //无空闲页面{MinT=100000;for(j=0;j<total_vp;j++){ //找出time的最小值,表明该页很久没被访问过if(MinT>pl[j].time&&pl[j].pfn!=INVALID){MinT=pl[j].time;MinPn=j;}}freepf_head=&pfc[pl[MinPn].pfn]; //最久没被访问过的页被释放pl[MinPn].pfn=INVALID; //最久没被访问过的页被换出主存pl[MinPn].time=-1; //最久没被访问过的页的访问时间置为无效freepf_head->next=NULL;}pl[page[i]].pfn=freepf_head->pfn; //有空闲页面,把相应的页面换入主存,并把pfn改为相应的帧号pl[page[i]].time=CurrentTime; //令访问时间为当前系统时间freepf_head=freepf_head->next; //减少一个空闲页面}elsepl[page[i]].time=CurrentTime; //命中则刷新该单元的访问时间CurrentTime++; //系统当前时间加}printf("%6.3f\t",1-(float)diseffect/320);return 0;}//最佳置换算法//int total_pf; 用户进程的内存页面数int OPT(int total_pf){int i,j;int MaxD; //将来最近一次访问的距离的最大值(以时间单元度量)int MaxPn; //将来最近一次访问的距离的最大值的页号int dis; //距离计数器int dist[total_vp]; //距离数组,保存距离上一次访问的时间差距个数initialize(total_pf); //初始化页面结构数组和页面控制结构数组diseffect=0;for(i=0;i<total_instruction;i++){if(pl[page[i]].pfn==INVALID) //页面失效{diseffect++; //页错误次数加if(freepf_head==NULL) //无空闲页面{for(j=0;j<total_vp;j++){if(pl[j].pfn!=INVALID) //如果该页在主存中dist[j]=100000; // 该页关联的距离值改为最大值elsedist[j]=0; //如果不在该页主存中,该页关联的距离值改为}dis=1; //初始距离值为for(j=i+1;j<total_instruction;j++) //从要替换的指令的下一条算起,{if(pl[page[j]].pfn!=INVALID &&pl[page[j]].counter==0) //如果该页在主存中,并且是将要最近访问的页//if(pl[page[j]].pfn!=INVALID && dist[page[j]]==100000) //此条语句原理与上相同{ dist[page[j]]=dis; //距离值改为displ[page[j]].counter=1; //使访问次数标志加,区别第一次访问和第二次访问}dis++;}MaxD=-1;for(j=0;j<total_vp;j++){pl[j].counter=0; //重置访问次数为if(MaxD<dist[j]) //查找将来最近一次访问的距离的最大值及其序号{MaxD=dist[j];MaxPn=j;}}freepf_head=&pfc[pl[MaxPn].pfn]; //替换将来一段时间最久访问的页freepf_head->next=NULL;pl[MaxPn].pfn=INVALID;}pl[page[i]].pfn=freepf_head->pfn; //把当前页换入主存中,并且把当前页的pfn改为换入页的帧号,freepf_head=freepf_head->next; //减少一个空闲页面}//if}//forprintf("%6.3f\t",1-(float)diseffect/320);return 0;}//简单时钟算法//int total_pf; 用户进程的内存页面数int CLOCK(int total_pf){int i;int use[total_vp]; //使用位int swap;swap=0; //发生替换initialize(total_pf);pfc_type *pnext; //时钟指针pfc_type *head; //队列头指针pnext=freepf_head;head=freepf_head;for(i=0;i<total_vp;i++){use[i]=0;} //初始化使用位为diseffect=0;for(i=0;i<total_instruction;i++){if (pl[page[i]].pfn==INVALID) //页面失效,不在主存中{diseffect++; //页错误次数加if(freepf_head==NULL) //无空闲页面{while(use[pnext->pfn]==1) //若时钟指针指向的页的使用位为,则改为并跳过{use[pnext->pfn]=0;pnext=pnext->next;if(pnext==NULL) pnext=head; //如果时钟指针到达队列尾部,重新返回头部}//换出被替换的页pl[pnext->pn].pfn=INVALID;swap=1;}if(use[pnext->pfn]==0){ //如果使用位为,则换入相应的页pl[page[i]].pfn=pnext->pfn; //页面结构中要标记帧号pnext->pn=page[i]; //页面控制结构中要标记页号use[pnext->pfn]=1; //重置使用位为pnext=pnext->next; //时钟指针下移if(pnext==NULL) pnext=head; //如果时钟指针到达队列尾部,重新返回头部if(swap==0){ freepf_head=freepf_head->next; }}}else{//页面在主存中use[pl[page[i]].pfn]=1; //刷新使用位为}}printf("%6.3f\t",1-(float)diseffect/320);return 0;}//先进先出算法版本//int total_pf; 用户进程的内存页面数//实现细节由CLOCK算法退化而来,与FIFO同效果int FIFO(int total_pf){int i;int use[total_vp];int swap=0;initialize(total_pf);pfc_type *pnext,*head;pnext=freepf_head;head=freepf_head;for(i=0;i<total_vp;i++){use[i]=0;}diseffect=0;for(i=0;i<total_instruction;i++){if (pl[page[i]].pfn==INVALID) //页面失效,不在主存中{diseffect++;if(freepf_head==NULL) //无空闲页面{while(use[pnext->pfn]==1){use[pnext->pfn]=0;pnext=pnext->next;if(pnext==NULL) pnext=head;}//换出被替换的页pl[pnext->pn].pfn=INVALID;swap=1;}if(use[pnext->pfn]==0){ //如果使用位为,则换入相应的页pl[page[i]].pfn=pnext->pfn; //页面结构中要标记帧号pnext->pn=page[i]; //页面控制结构中要标记页号use[pnext->pfn]=1; //重置使用位为pnext=pnext->next;if(pnext==NULL) pnext=head;if(swap==0){ freepf_head=freepf_head->next; }}}}printf("%6.3f\t",1-(float)diseffect/320);return 0;}<实验结果>比较上述4种算法,以OPT算法的命中率最高,LRU算法次之,再就是CLOCK算法FIFO 算法。