文档库 最新最全的文档下载
当前位置:文档库 › 实验七 磁盘管理

实验七 磁盘管理

实验七 磁盘管理
实验七 磁盘管理

实验七磁盘管理

一、实验目的

1.掌握基本磁盘的管理方法

2.掌握动态磁盘的管理方法。

二、实验环境

1、安装有Windows Server 2008虚拟机软件的计算机

三、实验作业

将操作结果数据保存到WORD文档中,名称为班级-姓名-学号.doc,例如1班张三1号的文件名为:1-张三-01.doc。

操作结束将实验作业文档提交。

四、实验内容

1、每次实验必做内容

1)卸载原有的VMware虚拟机,并重装虚拟机

2)打开虚拟机软件,运行Win2008的虚拟计算机;然后选择【虚拟机】菜单【设置】,在打开的对话框中找到【网络适配器】,将右上角的【已连接】复选框打上对号。

3)修改计算机名,并重新启动

命名为student班级学号,例如1班一号的计算机名称为:student101。

4)配置TCP/IP参数

打开【网络和共享中心】,单击本地连接的【查看状态】,自己设置静态IP信息:IP地址:192.168.0.XXX(XXX为分配给你的号码,要

记清楚);子网掩码:255.255.255.0;把IP属性截图到实验作业中。设置结束,再次查看当前计算机的TCP/IP参数,如有冲突,换IP。5)、设置网络发现和共享

在【网络和共享中心】设置网络发现、文件共享的启用。

6)双击桌面的【网络】,查看虚拟机的网络连接情况

2、在虚拟机中添加3块硬盘,大小都是1G

1)选择【虚拟机】-【设置】,在打开的对话框中选择【添加】按钮,选择硬盘并单击下一步。

2)按默认设置,注意保存虚拟硬盘文件的位置及名称。

3)打开【计算机管理】控制台,对添加的硬盘进行【联机】和【初始化】操作。

初始化磁盘有两种分区形式,请选择默认的MBR 主启动记录。 3、基本磁盘管理

1)打开【计算机管理】控制台,选择磁盘管理中的磁盘1,在该硬盘中创建三个主磁盘分区、一个扩展磁盘分区、两个逻辑驱动器,创建结果如下表:

创建结果如图,将创建结果截图到实验作业中。

2)回答下面的问题:

(1)按以上方式划分了分区后,打开我的电脑,可以看到该硬盘中的哪几个分区?

(2)能否为扩展磁盘分区指派一个驱动器号或路径?

(3)如果想要为逻辑驱动器2重新指派一个驱动器号,该如何做?

(4)想要把逻辑驱动器2的文件系统改为NTFS,该如何做?

4、基本磁盘与动态磁盘的转换

在磁盘1创建的分区中随意创建几个文件夹和文件

1)把磁盘1转换为动态磁盘

(1)【计算机管理】【磁盘管理】选项,对磁盘1上单击鼠标右键,在弹出的菜单中选择“转换到动态磁盘”

(2)选择需要转换的磁盘并确定。在弹出来的对话框中选择是。

(3)将转换后结果的磁盘管理窗口截图到实验作业。

(4)查看写入磁盘1中分区的文件夹及文件,是否有变化?

2)动态磁盘转换基本磁盘

(1)【计算机管理】【磁盘管理】选项,对磁盘1上单击鼠标右键。此时“转换成基本磁盘”选项为灰色。

(2)只有将磁盘1中的所有分区都删除,将自动转换成基本磁盘,请验证将磁盘1转换成基本磁盘。

3)回答下面的问题:

(1)已经划分好的基本磁盘能否直接转换为动态磁盘?

(2)由基本磁盘转换为动态磁盘后,磁盘中原有内容是否会丢失?

(3)已经划分好的动态磁盘能否直接转换为基本磁盘?

(4)由动态磁盘转换为基本磁盘后,磁盘中原有内容是否会丢失?

5、简单卷和跨区卷

利用磁盘1和磁盘2创建,将磁盘1中所有分区删除。

1)创建简单卷:

(1)在磁盘1中创建一个简单卷E,卷的大小为100M。

(2) 在“磁盘管理”中,右键单击未分配的空间,并选择“简单卷”并根据屏幕提示输入相关信息。

2)创建跨区卷:

(1)在磁盘1和磁盘2中创建一个跨区卷F,大小为300M,其中磁盘1占200M,磁盘2占100M。

(2)在“磁盘管理”中,右键单击未分配的空间,并选择“跨区卷”并单击“下一步”。然后根据屏幕指示完成向导。

3)回答下面的问题:

(1)通过“计算机”访问这些卷,创建一些文件和文件夹。它们在使用上与基本磁盘的分区有没有区别?

(2)扩展简单卷或跨区卷的容量,都在磁盘1中增加50M,通过“计算机”查看它的容量变化,扩展容量后其中原有的内容是否会丢失?如果简单卷在磁盘2扩展50M,会有什么变化?

(3)禁用磁盘1或磁盘2(假设该磁盘出现故障),两个卷E和F会出现什么情况?

6、带区卷RAID-0

1)创建带区卷:

(1)在磁盘1和磁盘2中创建一个带区卷G,大小为200M。

(2)在“磁盘管理”中,右键单击未分配的空间,并选择“带区卷”并单击“下一步”。然后根据屏幕指示完成向导。

(3)用“计算机”在该卷中放置几个文件(文件大小应大于64KB,最好是文本、图片等可打开的文件);

2)回答下面的问题:

(1)禁用磁盘1或磁盘2(假设该磁盘出现故障),文件是否还可以访问?

(2)文件在带区卷上是如何存放的?这样的存放方法有什么好处?7、镜像卷RAID-1

1)创建镜像卷

(1)在磁盘1和磁盘2中创建一个镜像卷H,大小为200M。

(2)在“磁盘管理”中,右键单击未分配的空间,并选择“镜像卷”并单击“下一步”。然后根据屏幕指示完成向导。

(3)用“计算机”在该卷中放置几个文件(最好是文本、图片等可打开的文件);

2)回答下面的问题:

(1)禁用磁盘1或磁盘2(假设该磁盘出现故障),文件是否还可以访问?

(2)文件在镜像卷上是如何存放的?这样的存放方法有什么好处?实际可用空间有多大?

8、RAID-5 卷

1)创建RAID-5卷

(1)在磁盘1、磁盘2和磁盘3中创建一个跨区卷I,大小为300M。

(2) 在“磁盘管理”中,右键单击未分配的空间,选择“RAID5卷”。

(3)选择想使用的三块磁盘并输入分配给该卷的空间大小,单击“下一步”并根据屏幕指导完成向导。

(4)用“我的电脑”在该卷中放置几个文件(最好是文本、图片等可打开的文件);

2)回答下面的问题:

(1)禁用磁盘1或磁盘2(假设该磁盘出现故障),文件是否还可以访问?

(2)文件在RAID-5 上是如何存放的?这样的存放方法有什么好处?实际可用空间有多大?

9、利用diskpart命令实现磁盘管理。

操作系统磁盘调度算法实验报告

《操作系统原理》 课程设计报告书 题目:磁盘调度 专业:网络工程 学号: 学生姓名: 指导教师: 完成日期:

目录 第一章课程设计目的 (1) 1.1编写目的 (1) 第二章课程设计内容 (2) 2.1设计内容 (2) 2.1.1、先来先服务算法(FCFS) (2) 2.1.2、最短寻道时间优先算法(SSTF) (2) 2.1.3、扫描算法(SCAN) (3) 2.1.4、循环扫描算法(CSCAN) (3) 第三章系统概要设计 (4) 3.1模块调度关系图 (4) 3.2模块程序流程图 (4) 3.2.1 FCFS算法 (5) 3.2.2 SSTF算法 (6) 3.2.3 SCAN算法 (7) 3.2.4 CSCAN算法 (8) 第四章程序实现 (9) 4.1 主函数的代码实现 (9) 4.2.FCFS算法的代码实现 (11) 4.3 SSTF算法的代码实现 (13) 4.4 SCAN算法的代码实现 (15) 4.5 CSCAN算法的代码实现 (17) 第五章测试数据和结果 (20) 第六章总结 (23)

第一章课程设计目的 1.1编写目的 本课程设计的目的是通过磁盘调度算法设计一个磁盘调度模拟系统,从而使磁盘调度算法更加形象化,容易使人理解,使磁盘调度的特点更简单明了,能使使用者加深对先来先服务算法、最短寻道时间优先算法、扫描算法以及循环扫描算法等磁盘调度算法的理解 1

第二章课程设计内容 2.1设计内容 系统主界面可以灵活选择某种算法,算法包括:先来先服务算法(FCFS)、最短寻道时间优先算法(SSTF)、扫描算法(SCAN)、循环扫描算法(CSCAN)。 2.1.1、先来先服务算法(FCFS) 这是一种比较简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。此算法由于未对寻道进行优化,在对磁盘的访问请求比较多的情况下,此算法将降低设备服务的吞吐量,致使平均寻道时间可能较长,但各进程得到服务的响应时间的变化幅度较小。 2.1.2、最短寻道时间优先算法(SSTF) 该算法选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短,该算法可以得到比较好的吞吐量,但却不能保证平均寻道时间最短。其缺点是对用户的服务请求的响应机会不是均等的,因而导致响应时间的变化幅度很大。在服务请求很多的情况下,对内外边缘磁道的请求将会无限期的被延迟,有些请求的响应时间将不可预期。 2

操作系统实验报告模板

操作系统上机 实验报告 成绩 教师: 2012 年 12月 5日 班级: 学号: 姓名: 实验地点: 实验时间:

实验一进程的建立 【实验目的】 创建进程及子进程 在父子进程间实现进程通信 【实验软硬件环境】 Linux 、Windows98、Windows2000 【实验内容】 创建进程并显示标识等进程控制块的属性信息; 显示父子进程的通信信息和相应的应答信息。 (进程间通信机制任选) 【实验程序及分析】 编程思路:首先本程序在Linux用C语言完成的,父子进程的创建用fork函数来实现,然后是父子进程间的通信,这里用pipe实现。可以定义chan1[2], chan1[2],chanx[0]表示读,chanx[1]表示写。他们配合使用。 【实验截图】 【实验心得体会】 通过这次上机练习,我熟悉了用c++实现进程的创建,销毁,父子进程间的通讯等一系列课程中需要学习的内容。本来进程的概念在一开始我始终无法清晰地理解,但是通过自己用mfc的方法去实现它后,我开始慢慢地理解操作系统的进程的运作机制。 虽然,我只是实现了一个父子进程的创建和通讯,但是,管中窥豹,我想自己开始明白一个操作系统正是由很多这种进程实现功能的。其中,系统整体的进程调度,管理等等还有很多东西等着我们去进一步学习、理解。 实验二进程间的同步 【实验目的】

理解进程同步和互斥模型及其应用 【实验软硬件环境】 Linux 、Windows98、Windows2000 【实验内容】 利用通信API实现进程之间的同步: 建立司机和售票员进程; 并实现他们间的同步运行。 【实验程序及分析】 程序总体思路:由于本次试验时用PV操作实现的互斥与同步模型,所以先实现P、V操作的函数,然后在主程序中利用PV操作函数实现司机和售票员的同步。司机和售票员分别为父进程和子进程,假设司机停车开门,此时为父进程中运行,然后申请开车,但是此时乘客没上车,所以只能阻塞。此时进入子进程,乘客上车,关门,售票员检票,释放开车,然后死机开车,到站,释放开车门。如此循环。 示意图 #include #include

第七章 设备管理复习题

一、填空题: 1、影响磁盘访问时间的三个因素是_寻道时间_、_旋转延迟 __和_传输时间_。 2、SPOOLing系统中,作业执行时,从磁盘上的输入井中 读取信息,并把作业的执行结果暂时存放在磁盘上的_输出井_中。 3、操作系统的设备管理应具备的主要功能是监视设备状态、 进行设备分配、_完成I/O操作_和缓冲管理。 4、从资源分配的角度看,可以把设备分为独占设备、共享设 备和虚拟设备。打印机属于独占设备,而磁盘属于____设备。 5、虚拟设备是通过技术把_____设备变成能为若干用 户______的设备。 6、缓冲区的设置可分为、和______三种。 7、常用的设备分配算法是和。 8、在设备管理中,为了克服独占设备速度较慢、降低设备资 源利用率的缺点,引入了,即用共享设备模拟独占设备。 9、操作系统管理使用数据结构,使用表管理进程, 使用表管理作业,使用表管理文件。 参考答案:

1、寻道时间旋转延迟时间传输时间 2、输入井输出井 3、设备分配设备驱动设备无关性 4、虚拟设备独占共享 5、SPOOLing 独占共享 6、单缓冲双缓冲多缓冲 7、先来先服务优先级高者优先 8、虚拟分配技术 二、选择题 1、在存储型设备中,执行信息传输的最小单位是(C ) A 字节B字C块D字符 2、虚拟设备是通过(A )操作实现的 A 联机外围设备同时B联机外围设备分时 C脱机外围设备同时D脱机外围设备分时 3、设备独立性的含义是(B ) A 每一台设备都有一个唯一的编号 B 程序中使用的设备与实际使用哪台物理设备无关 C 多台设备不能并行工作 D 一个通道上只准连接一台设备 4、缓冲技术的缓冲池(多缓冲的一种组织形式)在(A )中 A 主存 B 外存 C ROM D 寄存器

操作系统磁盘调度算法实验报告

操作系统磁盘调度算法 实验报告 Company number:【0089WT-8898YT-W8CCB-BUUT-202108】

目录

1.课程设计目的 编写目的 本课程设计的目的是通过磁盘调度算法设计一个磁盘调度模拟系统,从而使磁盘调度算法更加形象化,容易使人理解,使磁盘调度的特点更简单明了,能使使用者加深对先来先服务算法、最短寻道时间优先算法、扫描算法以及循环扫描算法等磁盘调度算法的理解。 2.课程设计内容 设计内容 系统主界面可以灵活选择某种算法,算法包括:先来先服务算法(FCFS)、最短寻道时间优先算法(SSTF)、扫描算法(SCAN)、循环扫描算法(CSCAN)。 1、先来先服务算法(FCFS) 这是一种比较简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进

程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。此算法由于未对寻道进行优化,在对磁盘的访问请求比较多的情况下,此算法将降低设备服务的吞吐量,致使平均寻道时间可能较长,但各进程得到服务的响应时间的变化幅度较小。 2、最短寻道时间优先算法(SSTF) 该算法选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短,该算法可以得到比较好的吞吐量,但却不能保证平均寻道时间最短。其缺点是对用户的服务请求的响应机会不是均等的,因而导致响应时间的变化幅度很大。在服务请求很多的情况下,对内外边缘磁道的请求将会无限期的被延迟,有些请求的响应时间将不可预期。 3、扫描算法(SCAN) 扫描算法不仅考虑到欲访问的磁道与当前磁道的距离,更优先考虑的是磁头的当前移动方向。例如,当磁头正在自里向外移动时,扫描算法所选择的下一个访问对象应是其欲访问的磁道既在当前磁道之外,又是距离最近的。这样自里向外地访问,直到

操作系统-第七章 设备管理习题(有答案)

第七章设备管理习题 一. 选择最合适的答案 1.在下面的I/O控制方式中,需要CPU干预最少的方式是()。 (A)程序I/O方式 (B)中断驱动I/O控制方式 (C)直接存储器访问DMA控制方式 (D)I/O通道控制方式 2.某操作系统中,采用中断驱动I/O控制方式,设中断时,CPU用1ms来处理中断请求,其它时间CPU完全用来计算,若系统时钟中断频率为100H Z,则,CPU的利用率为()。 (A)60% (B)70% (C)80% (D)90% 3.下列哪一条不是磁盘设备的特点()。 (A)传输速率较高,以数据块为传输单位 (B)一段时间内只允许一个用户(进程)访问 (C)I/O控制方式常采用DMA方式 (D)可以寻址,随机地读/写任意数据块 4.利用通道实现了()之间数据的快速传输。 (A)CPU和外设(B)内存和CPU (C)内存和外设(D)外设和外设 5.假脱机技术中,对打印机的操作实际上是用对磁盘存储实现的,用以替代打印机的部分是指()。 (A)共享设备(B)独占设备 (C)虚拟设备(D)物理设备 6.设从磁盘将一块数据传送到缓冲区所用时间为80μs,将缓冲区中数据传送到用户区所用时间为40μs,CPU处理数据所用时间为30μs,则处理该数据,采用单缓冲传送某磁盘数据,系统所用总时间为()。 (A)120μs (B)110μs (C)150μs (D)70μs 7.对于速率为9.6KB/s的数据通信来说,如果说设置一个具有8位的缓冲寄存器,则CPU中断时间和响应时间大约分别为()。 (A)0.8ms,0.8ms (B)8ms,1ms (C)0.8ms,0.1ms (D)0.1ms,0.1ms 8.在调试程序时,可以先把所有输出送屏幕显示而不必正式输出到打印设备,其运用了()。

第七章 磁盘高级管理

第七章磁盘高级管理 一、管理磁盘配额 磁盘配额是对文件系统设定的,设定之前需要启用文件系统的配额支持。在Linux系统中,磁盘配额可以从两方面限制磁盘的使用。 ?文件数量:用户能够使用的索引节点数(inode),限制用户可以创建的文件数量。 ?磁盘容量:用户能够使用的磁盘块区数(block),会限制用户可以使用的磁盘容量。磁盘配额的限制方法。 ?软限制:指定一个软性的配额数值(例100M磁盘空间、180个文件),在固定的宽限期(默认为七天)内允许超过这个限制,但系统会给出警告信息。 ?硬限制:指定一个硬性的配额数值(例于120M磁盘空间,200个文件),是绝对禁止用户超过的限制值,当达到硬性限制时,系统会给出警告并禁止继续写入数 据。硬限制的配额值应大于相应的软限制,否则软限制将失效。 下面以上小节中创建的分区/dev/sdb1为例,将期挂载到/soft目录下,并启用磁盘配额功能,可以按照如下步骤操作: 1、首先检查是否安装了quota软件包,大部分情况下系统会默认安装的。可以通过以下命令检查quota软件包的安装情况。 2、以支持配额功能的方式挂载文件系统。可以使用 –o usrquota,grpquota选项的mount 命令重新挂载指定的分区。 3、若需要每次开机自动以支持配额功能方式挂载该分区,需要修改/etc/fstab文件。为了启用对用户的配额,需要在文件系统的选项列中加入usrquota项;为了启用对组的配额,需要在文件系统的选项列中加入grpquota项。如下所示: 4、运行quotacheck命令生成磁盘配额文件,可以运行如下命令:

其中-a表示描扫所有分区,-c选项用来生成配额文件(aquota.group和https://www.wendangku.net/doc/7f14830815.html,er),-u 选项检查用户配额,-g选项检查组配额,-v表示显示细节。系统在运行配额检查时会在配额文件中创建磁盘使用信息。 5、编辑用户和组的配额限制 配额设置是实现磁盘配额功能中最重要的环节,使用edquota 命令结-u 和-g选项可以用于编辑用户或组的配额设置。 假设要为用户lipi设置磁盘配额,可运行如下命令:(针对用户设置配额时,-u选项可省) 系统会默认调用vi编辑器进行编辑,内容如下: 从左到右这七个字段的含义如下所示。 ?Filesystem:文件系统(分区)。 ?Blocks:当前用户已经使用的磁盘容量,默认单位为KB,该数值自动计算,无需修改。 ?Soft :磁盘容量的软限制数值,默认单位为KB。 ?Hard KB。 ?Inodes:当前用户已拥有i节点数量(文件数量),该值无需修改 ?Soft :文件数量的软限制数值,默认单位为个。 ?Hard:文件数量的软限制数值,默认单位为个。

天津理工大学操作系统实验3:磁盘调度算法的实现

人和以吟实验报告学院(系)名称:计算机与通信工程学院

【实验过程记录(源程序、测试用例、测试结果及心得体会等) 】 #include #include #include using namespace std; void Inith() { cout<<" 请输入磁道数: "; cin>>M; cout<<" 请输入提出磁盘 I/O 申请的进程数 cin>>N; cout<<" 请依次输入要访问的磁道号: "; for(int i=0;i>TrackOrder[i]; for(int j=0;j>BeginNum; for(int k=0;k=0;i--) for(int j=0;jSortOrder[j+1]) const int MaxNumber=100; int TrackOrder[MaxNumber]; int MoveDistance[MaxNumber]; // ------- int FindOrder[MaxNumber]; // ---------- double AverageDistance; // ----------- bool direction; // int BeginNum; // int M; // int N; // int SortOrder[MaxNumber]; // ------ bool Finished[MaxNumber]; 移动距离 ; 寻好序列。 平均寻道长度 方向 true 时为向外, false 开始磁道号。 磁道数。 提出磁盘 I/O 申请的进程数 排序后的序列 为向里

天津理工大学 操作系统实验3:磁盘调度算法地实现

实验报告学院(系)名称:计算机与通信工程学院

【实验过程记录(源程序、测试用例、测试结果及心得体会等)】 #include #include #include using namespace std; const int MaxNumber=100; int TrackOrder[MaxNumber]; int MoveDistance[MaxNumber]; //----移动距离; int FindOrder[MaxNumber]; //-----寻好序列。 double AverageDistance; //-----平均寻道长度 bool direction; //-----方向 true时为向外,false为向里 int BeginNum; //----开始磁道号。 int M; //----磁道数。 int N; //-----提出磁盘I/O申请的进程数 int SortOrder[MaxNumber]; //----排序后的序列 bool Finished[MaxNumber]; void Inith() { cout<<"请输入磁道数:"; cin>>M; cout<<"请输入提出磁盘I/O申请的进程数:"; cin>>N; cout<<"请依次输入要访问的磁道号:"; for(int i=0;i>TrackOrder[i]; for(int j=0;j>BeginNum; for(int k=0;k=0;i--) for(int j=0;jSortOrder[j+1])

磁盘调度实验报告

操作系统实验报告课程名称:计算机操作系统 实验项目名称:磁盘调度实验时间: 班级:姓名:学号: 实验目的: 对操作系统的磁盘调度基础理论和重要算法的理解,加强动手能力。 实验环境: PC机 win7 Visual C++ 实验内容: 编程序实现下述磁盘调度算法,并求出每种算法的平均寻道长度,要求设计主界面以灵 活选择某算法,且以下算法都要实现: 1、先来先服务算法(FCFS) 2、最短寻道时间优先算法(SSTF) 3、扫描算法(SCAN) 4、循环扫描算法(CSCAN) 实验过程: 1.依次输入8个磁道数:123 45 31 67 20 19 38,并以0 结束 2.选择调度算法: (1)先来先服务算法(FCFS) (2)最短寻道时间优先算法(SSTF) 成绩: 指导教师(签名):

(3)扫描算法(SCAN) (4)循环扫描算法(CSCAN) 实验心得: 通过本次实验,学习了解磁盘调度的工作原理及四种调度方法的工作原理,并且在当中

发现了自己的不足,对以前所学过的知识理解得不够深刻,掌握得不够牢固,看到了自己的实践经验还是比较缺乏,理论联系实际的能力还急需提高。 附录: #include #include #include #include #define maxsize 1000 /*********************判断输入数据是否有效**************************/ int decide(char str[]) //判断输入数据是否有效 { int i=0; while(str[i]!='\0') { if(str[i]<'0'||str[i]>'9') { return 0; break; } i++; } return i; } /******************将字符串转换成数字***********************/ int trans(char str[],int a) //将字符串转换成数字 { int i; int sum=0; for(i=0;icidao[j]) { temp=cidao[i]; cidao[i]=cidao[j]; cidao[j]=temp; } } cout<<" 排序后的磁盘序列为:"; for( i=0;i

操作系统实验 磁盘调度算法

操作系统 实验报告 哈尔滨工程大学 计算机科学与技术学院

第六讲磁盘调度算法 一、实验概述 1. 实验名称 磁盘调度算法 2. 实验目的 (1)通过学习EOS 实现磁盘调度算法的机制,掌握磁盘调度算法执行的条件和时机; (2)观察 EOS 实现的FCFS、SSTF和 SCAN磁盘调度算法,了解常用的磁盘调度算法; (3)编写 CSCAN和 N-Step-SCAN磁盘调度算法,加深对各种扫描算法的理解。 3. 实验类型 验证性+设计性实验 4. 实验内容 (1)验证先来先服务(FCFS)磁盘调度算法; (2)验证最短寻道时间优先(SSTF)磁盘调度算法; (3)验证SSTF算法造成的线程“饥饿”现象; (4)验证扫描(SCAN)磁盘调度算法; (5)改写SCAN算法。 二、实验环境 在OS Lab实验环境的基础上,利用EOS操作系统,由汇编语言及C语言编写代码,对需要的项目进行生成、调试、查看和修改,并通过EOS应用程序使内核从源代码变为可以在虚拟机上使用。 三、实验过程 1. 设计思路和流程图 (1)改写SCAN算法 在已有 SCAN 算法源代码的基础上进行改写,要求不再使用双重循环,而是只遍历一次请求队列中的请求,就可以选中下一个要处理的请求。算法流程图如下图所示。 图 3.1.1 SCAN算法IopDiskSchedule函数流程图(2)编写循环扫描(CSCAN)磁盘调度算法 在已经完成的SCAN算法源代码的基础上进行改写,不再使用全局变量ScanInside 确定磁头移动的方向,而是规定磁头只能从外向内移动。当磁头移动到最内的被访问磁道时,磁头立即移动到最外的被访问磁道,即将最大磁道号紧接着最小磁道号构成循环,进行扫描。算法流程图如下图所示。

磁盘调度实验报告

操作系统实验报告 磁 盘 调 度

实验六:磁盘调度算法 一.实验目的 复习模拟实现一种磁盘调度算法,进一步加深对磁盘调度效率的理解。 二.实验属性 该实验为设计性实验。 三.实验仪器设备及器材 普通PC386以上微机 四.实验要求 本实验要求2学时完成。 本实验要求完成如下任务: (1)建立相关的数据结构,作业控制块、已分配分区及未分配分区 (2)实现一个分区分配算法,如最先适应分配算法、最优或最坏适应分配算法(3)实现一个分区回收算法 (4)给定一批作业/进程,选择一个分配或回收算法,实现分区存储的模拟管理

实验前应复习实验中所涉及的理论知识和算法,针对实验要求完成基本代码编写并完成预习报告、实验中认真调试所编代码并进行必要的测试、记录并分析实验结果。实验后认真书写符合规范格式的实验报告(参见附录A),并要求用正规的实验报告纸和封面装订整齐,按时上交。 五 .主要算法分析 各个算法分析 1.先来先服务算法(FCFS) 先来先服务(FCFS)调度:按先来后到次序服务,未作优化。 最简单的移臂调度算法是“先来先服务”调度算法,这个算法实际上不考虑访问者要求访问的物理位置,而只是考虑访问者提出访问请求的先后次序。例如,如果现在读写磁头正在50号柱面上执行输出操作,而等待访问者依次要访问的柱面为130、199、32、159、15、148、61、99,那么,当50号柱面上的操作结束后,移动臂将按请求的先后次序先移到130号柱面,最后到达99号柱面。 采用先来先服务算法决定等待访问者执行输入输出操作的次序时,移动臂来回地移动。先来先服务算法花费的寻找时间较长,所以执行输入输出操作的总时间也很长。 2.最短寻道时间优先算法(SSTF) 最短寻找时间优先调度算法总是从等待访问者中挑选寻找时间最短的那个请求先执行的,而不管访问者到来的先后次序。现在仍利用同一个例子来讨论,现在当50号柱面的操作结束后,应该先处理61号柱面的请求,然后到达32号柱面执行操作,随后处理15号柱面请求,后继操作的次序应该是99、130、148、159、199。 采用最短寻找时间优先算法决定等待访问者执行操作的次序时,读写磁头总共移动了200多个柱面的距离,与先来先服务、算法比较,大幅度地减少了寻找时间,因而缩短了为各访问者请求服务的平均时间,也就提高了系统效率。 但最短查找时间优先(SSTF)调度,FCFS会引起读写头在盘面上的大范围移动,SSTF查找距离磁头最短(也就是查找时间最短)的请求作为下一次服务的对象。SSTF查找模式有

磁盘调度算法实验报告 (2)

磁盘调度算法 学生姓名: 学生学号: 专业班级: 指导老师: 2013年6月20日

1、实验目的: 通过这次实验,加深对磁盘调度算法的理解,进一步掌握先来先服务FCFS、最短寻道时间优先SSTF、SCAN和循环SCAN算法的实现方法。 2、问题描述: 设计程序模拟先来先服务FCFS、最短寻道时间优先SSTF、SCAN 和循环SCAN算法的工作过程。假设有n个磁道号所组成的磁道访问序列,给定开始磁道号m和磁头移动的方向(正向或者反向),分别利用不同的磁盘调度算法访问磁道序列,给出每一次访问的磁头移动距离,计算每种算法的平均寻道长度。 3、需求分析 通过这次实验,加深对磁盘调度算法的理解,进一步掌握先来先服务FCFS、最短寻道时间优先SSTF、SCAN和循环SCAN算法的实现方法。 通过已知开始磁道数、访问磁道总数、磁道号访问序列、访问方向及访问方式得到访问序列及移动距离和平均移动距离! (1)输入的形式; int TrackOrder[MaxNumber];//被访问的磁道号序列 int direction;//寻道方向 int Num;//访问的磁道号数目

int start;// (2)输出的形式; int MoveDistance[MaxNumber]={0};//移动距离 double AverageDistance=0;//平均寻道长度 移动的序列! (3)程序所能达到的功能; 模拟先来先服务FCFS、最短寻道时间优先SSTF、SCAN和循环SCAN算法的工作过程。假设有n个磁道号所组成的磁道访问序列,给定开始磁道号m和磁头移动的方向(正向或者反向),分别利用不同的磁盘调度算法访问磁道序列,给出每一次访问的磁头移动距离,计算每种算法的平均寻道长度。 (4)测试数据,包括正确的输入及其输出结果和含有错误的输入及其输出结果。 开始磁道号:100 磁道号方向:内(0)和外(1) 磁道号数目:9 页面序列:55 58 39 18 90 160 150 38 184 4、概要设计 说明本程序中用到的所有抽象数据类型的定义、主程序的流程以及各程序模块之间的层次(调用)关系。

操作系统实验报告

实验报告 实验课程名称:操作系统 实验地点:南主楼七楼机房 2018—2019学年(一)学期 2018年 9月至 2019 年 1 月 专业: 班级: 学号: 姓名: 指导老师:刘一男

实验一 实验项目:分时系统模拟 实验学时:2实验日期: 2018-10-25 成绩: 实验目的利用程序设计语言模拟分时系统中多个进程按时间片轮转调度算法进行进程调度的过程; 假设有五个进程A,B,C,D,E,它们的到达时间及要求服务的时间分别为:进程名 A B C D E 到达时间0 1 2 3 4 服务时间 4 3 4 2 4 时间片大小为1,利用程序模拟A,B,C,D,E五个进程按时间片轮转的调度及执行过程并计算各进程的周转时间及带权周转时间。 执行过程并计算各进程的周转时间及带权周转时间。 轮转调度:BDACE

(1)修改时间片大小为2,利用程序模拟A,B,C,D,E五个进程按时间片轮转的调度及执行过程并计算各进程的周转时间及带权周转时间。 轮转调度:ADBCE (2)修改时间片大小为4,利用程序模拟A,B,C,D,E五个进程按时间片轮转的调度及执行过程并计算各进程的周转时间及带权周转时间.

顺序:ABCDE 1、思考 时间片的大小对调度算法产生什么影响?对计算机的性能产生什么影响?答:通过对时间片轮转调度算法中进程最后一次执行时间片分配的优化,提出了一种改进的时间片轮转调度算法,该算法具有更好的实时性,同时减少了任务调度次数和进程切换次数,降低了系统开销,提升了CPU的运行效率,使操作系统的性能得到了一定的提高。 A B C D E 时间片为1 周转时间12 9 14 8 13 3 3 3.5 4 3.25 带权周转 时间 时间片为2 周转时间8 12 13 7 13 2 4 3.25 3.5 3.25 带权周转 时间 时间片为4 周转时间 4 6 9 10 13 1 2 2.25 5 3.25 带权周转 时间

操作系统磁盘调度算法

操作系统课程设计任务书 题目: 磁盘调度算法 院系: 专业: 班级: 姓名: 学号: 指导教师: 设计时间:2018.1.1-2018.1.5 指导教师评语

目录 1、需求分析?4 1.1课题描述 (4) 1.2课题目的 (4) 1.3理论依据?7 2、概要设计?8 2.1设计方法 ............................................................................................... 82.2技术?8 2.3运行环境?8 3、详细设计?9 3.1流程图 (11) 3.2程序主要代码? 13 14 4、运行结果及分析? 4.1运行结果? 15 4.2结果详细分析?6 1 16 5、总结和心得? 7 1 6、参考文献? 2 7、附录:程序源代码? 3

1、需求分析 1.1课题描述 这次课程设计我研究的题目是:磁盘调度算法。具体包括三种算法分别是:先来先服务算法(FCFS)、最短寻道时间优先算法(SSTF)、扫描算法(电梯调度算法)(SCAN)。 1.2课题目的 通过这次实验,加深对磁盘调度算法的理解,进一步掌握先来先服务FCFS,最短寻道时间优先SSTF,扫描SCAN算法的实现方法。 1.3理论依据 设备的动态分配算法与进程调度相似,也是基于一定的分配策略的。常用的分配策略有先请求先分配、优先级高者先分配等策略。在多道程序系统中,低效率通常是由于磁盘类旋转设备使用不当造成的。操作系统中,对磁盘的访问要求来自多方面,常常需要排队。这时,对众多的访问要求按一定的次序响应,会直接影响磁盘的工作效率,进而影响系统的性能。访问磁盘的时间因子由3部分构成,它们是查找(查找磁道)时间、等待(旋转等待扇区)时间和数据传输时间,其中查找时间是决定因素。因此,磁盘调度算法先考虑优化查找策略,需要时再优化旋转等待策略。 平均寻道长度(L)为所有磁道所需移动距离之和除以总的所需访问的磁道数(N),即:L=(M1+M2+……+Mi+……+MN)/N

操作系统实验报告

操作系统实验报告 学生学院计算机学院 专业班级计算机科学与技术3班学号3213005910 学生姓名林虹 指导教师丁国芳 2015 年12月15 日

目录 1 实验一进程调度 (1) 2 实验二银行家算法 (16) 3 实验三动态分区分配方式的模拟 (20) 4 实验四仿真各种磁盘调度算法 (26)

实验一进程调度 1. 实验目的 编写并调试一个模拟的进程调度程序,分别采用“短进程优先”、“时间片轮转”、“高响应比优先”调度算法对随机产生的五个进程进行调度,并比较算法的平均周转时间。以加深对进程的概念及进程调度算法的理解。 2. 实验要求 1.每个进程由一个进程控制块(PCB)表示,进程控制块可以包含如下信息:进程 名、优先数(响应比)、到达时间、需要运行时间(进程的长度)、已运行时间、进 程状态等等(可以根据需要自己设定)。 2.由程序自动生成进程(包括需要的数据,要注意数据的合理范围),第一个进程到 达时间从0开始,其余进程到达时间随机产生。 3.采用时间片轮转调度算法时,进程的运行时间以时间片为单位进行计算。 4.每个进程的状态可以是就绪W(Wait)、运行R(Run)、或完成F(Finish)三种 状态之一。 5.每进行一次调度,程序都要输出一次运行结果:正在运行的进程、就绪队列中的进 程、完成的进程以及各个进程的PCB,以便进行检查。 6.最后计算各调度算法的平均周转时间,并进行比较、分析。 3. 实验内容 a.算法原理 (1)短进程优先调度算法 “短进程优先”调度算法的基本思想是把CPU分配给就绪队列中需要时间最短的进程。 (2)时间片轮转算法 将系统中所有的就绪进程按照FCFS原则,排成一个队列。每次调度时将CPU 分派给队首进程,让其执行一个时间片。时间片的长度从几个ms到几百ms。在一个时间片结束时,发生时钟中断。调度程序据此暂停当前进程的执行,将其送到就绪队列的末尾,并通过上下文切换执行当前的队首进程。进程可以未使用完一个时间片,就出让CPU。 (3)高响应比优先算法 HRRN调度策略同时考虑每个作业的等待时间长短和估计需要的执行时间长短,从中选出响应比最高的作业投入执行。 每个作业完成后要打印该作业的开始运行时刻、完成时刻、周转时间和带权周转时间,这一组作业完成后要计算并打印这组作业的平均周转时间、带权平均周转时间。

《第七章》

第七章文件管理 一、单项选择题 1.操作系统中对数据进行管理的部分叫做_______. A.数据库系统 B.文件系统 C.检索系统 D.数据存储系统 2.文件系统中用_______管理文件。 A.作业控制块 B.外页表 C. 目录 D.软、硬件结合的方法 3.为解决不同用户文件的命名冲突问题通常在文件系统中采用______. A.约定的方法 B.多级目录 C.路径 D.索引 4.磁盘上的文件以_______为单位读写。 A.块 B.记录C柱面 D..磁道 5.磁带上的文件一般只能__________. A. 顺序存取 B.随机存取 C. 以字节为单位存取 D.直接存取 6.在下列文件的物理结构中,________不利于文件长度动态增长。 A.顺序结构 B.链接结构 C.索引结构 D.Hash结构 7.文件系统采用二级目录结构,这样可以________. A.缩短访问文件存储器时间 B.实现文件共享 C.节省主存空间 D.解决不同用户之间的文件名冲突问题。 8. _________是由字符序列组成的,不再划分结构。 A. 连续文件 B. 流式文件 C. 有序文件 D. 记录文件 9. 通常说的文件系统,指的是操作系统中的__________。 A.全部文件 B. 全部目录 C. 管理软件 D. 上述三种 10. 目录文件所存放的信息是_______。 A.某一文件存放的数据信息 B.某一文件的文件目录 C.该目录中所有数据文件目录 D.该目录中所有子目录文件和数据文件的目录 11. 在文件系统中,要求物理块必须连续的文件是_______。 A.索引文件 B. 顺序文件 C. 链接文件 D. 散列文件 12. 如果文件系统中存在两个文件重名,不应当采用________结构。 A.一级目录 B. 二级目录 C. 三级目录 D. 多级目录 13 在创建一个文件时,文件系统将为它建立一个_________。 A.逻辑空间 B. 逻辑结构 C. 文件目录 D. 目录文件 14. 在文件系统中,________负责将文件名转换为物理地址。 A.PCB 表 B. 文件路径 C. DCB表 D. 文件目录 15. 相同名字的文件应允许在一个系统中同时存在,解决这个问题的办法是__________。 A.通过文件共享 B. 多级目录管理 C. 采用索引文件 D. 文件安全管理 16. 文件系统概念中,级别由高到低排列的是_________。 A.文件、记录、数据项 B. 目录、文件、记录 C. 目录、记录、数据项 D. 数据项、记录、文件 17. 下列哪两种文件不必存放在连续的存储介质中__________。 A.链接文件和索引文件 B. 链接文件和索引顺序文件 C. 顺序文件和链接文件 D. 索引文件和顺序文件 18. 下列哪一个文件和其它三种文件在逻辑结构上根本不同___________。 A.可执行文件 B. 库函数文件 C. 源程序文件 D. 数据库文件 19. 下列选项中,_________不是删除文件中所需要完成的工作。 A.释放文件所占用的存储空间 B. 对文件原存储单元全部清零 C. 在目录中删除该文件

操作系统实验报告—磁盘调度算法

操作系统实验报告实验3 磁盘调度算法 报告日期:2016-6-17 姓名: 学号: 班级: 任课教师:

实验3 磁盘调度算法 一、实验内容 模拟电梯调度算法,实现对磁盘的驱动调度。 二、实验目的 磁盘是一种高速、大量旋转型、可直接存取的存储设备。它作为计算机系统的辅助存储器,负担着繁重的输入输出任务,在多道程序设计系统中,往往同时会有若干个要求访问磁盘的输入输出请示等待处理。系统可采用一种策略,尽可能按最佳次序执行要求访问磁盘的诸输入输出请求,这就叫驱动调度,使用的算法称驱动调度算法。驱动调度能降低为若干个输入输出请求服务所须的总时间,从而提高系统效率。本实验要求学生模拟设计一个驱动调度程序,观察驱动调度程序的动态运行过程。 三、实验原理 模拟电梯调度算法,对磁盘调度。 磁盘是要供多个进程共享的存储设备,但一个磁盘每个时刻只能为一个进程服务。当有进程在访问某个磁盘时,其他想访问该磁盘的进程必须等待,直到磁盘一次工作结束。当有多个进程提出输入输出请求处于等待状态,可用电梯调度算法从若干个等待访问者中选择一个进程,让它访问磁盘。当存取臂仅需移到一个方向最远的所请求的柱面后,如果没有访问请求了,存取臂就改变方向。 假设磁盘有200个磁道,用C语言随机函数随机生成一个磁道请求序列(不少于15个)放入模拟的磁盘请求队列中,假定当前磁头在100号磁道上,并向磁道号增加的方向上移动。请给出按电梯调度算法进行磁盘调度时满足请求的次序,并计算出它们的平均寻道长度。 四、实验过程 1.画出算法流程图。

2.源代码 #include #include #include int *Init(int arr[]) { int i = 0; srand((unsigned int)time(0)); for (i = 0; i < 15; i++) { arr[i] = rand() % 200 + 1; printf("%d ", arr[i]); } printf("\n"); return arr; } void two_part(int arr[]) { int i = 0; int j = 0;

操作系统磁盘调度算法实验报告

操作系统磁盘调度算法实 验报告 Last revision on 21 December 2020

目录

1.课程设计目的 编写目的 本课程设计的目的是通过磁盘调度算法设计一个磁盘调度模拟系统,从而使磁盘调度算法更加形象化,容易使人理解,使磁盘调度的特点更简单明了,能使使用者加深对先来先服务算法、最短寻道时间优先算法、扫描算法以及循环扫描算法等磁盘调度算法的理解。 2.课程设计内容 设计内容 系统主界面可以灵活选择某种算法,算法包括:先来先服务算法(FCFS)、最短寻道时间优先算法(SSTF)、扫描算法(SCAN)、循环扫描算法(CSCAN)。 1、先来先服务算法(FCFS) 这是一种比较简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进

程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。此算法由于未对寻道进行优化,在对磁盘的访问请求比较多的情况下,此算法将降低设备服务的吞吐量,致使平均寻道时间可能较长,但各进程得到服务的响应时间的变化幅度较小。 2、最短寻道时间优先算法(SSTF) 该算法选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短,该算法可以得到比较好的吞吐量,但却不能保证平均寻道时间最短。其缺点是对用户的服务请求的响应机会不是均等的,因而导致响应时间的变化幅度很大。在服务请求很多的情况下,对内外边缘磁道的请求将会无限期的被延迟,有些请求的响应时间将不可预期。 3、扫描算法(SCAN) 扫描算法不仅考虑到欲访问的磁道与当前磁道的距离,更优先考虑的是磁头的当前移动方向。例如,当磁头正在自里向外移动时,扫描算法所选择的下一个访问对象应是其欲访问的磁道既在当前磁道之外,又是距离最近的。这样自里向外地访问,直到

实验报告六 磁盘调度算法

实验报告六磁盘调度算法 班级:软技2班学号:201467003084 姓名:刘道林 一.实验内容:熟悉磁盘的结构以及磁盘的驱动调度算法的模拟,编程实现简单常用的磁盘驱动调度算法先来先服务(FIFO)、 电梯调度算法、最短寻找时间优先算法、扫描(双向扫描)算法、单向扫描(循环扫描)算法等。编程只需实现两个算法。题目可 以选取教材或习题中的相关编程实例。编程语言建议采用c/c++或Java。模拟程序鼓励采用随机数技术、动态空间分配技术,有条件 的最好能用图形界面展现甚至用动画模拟。实验性质:验证型。 二.实验目的和要求1)掌握使用一门语言进行磁盘驱动调度算法的模拟;2)编写程序将磁盘驱动调度算法的过程和结果能以 较简明直观的方式展现出来。 三.实验原理、方法和步骤 1. 实验原理 磁盘驱动调度对磁盘的效率有重要影响。磁盘驱动调度算法的好坏直接影响辅助存储器的效率,从而影响计算机系统的整体效率。 常用的磁盘驱动调度算法有:最简单的磁盘驱动调度算法是先入先出(FIFO)法。这种算法的实质是,总是严格按时间顺序对磁盘请 求予以处理。算法实现简单、易于理解并且相对公平,不会发生进程饿死现象。但该算法可能会移动的柱面数较多并且会经常更换移 动方向,效率有待提高。最短寻找时间优先算法:总是优先处理最靠近的请求。该算法移动的柱面距离较小,但可能会经常改变 移动方向,并且可能会发生进程饥饿现象。电梯调度:总是将一个方向上的请求全部处理完后,才改变方向继续处理其他请求。 扫描(双向扫描):总是从最外向最里进行扫描,然后在从最里向最外扫描。该算法与电梯调度算法的区别是电梯调度在没有最外或 最里的请求时不会移动到最外或最里柱面,二扫描算法总是移到最外、最里柱面。两端的请求有优先服被务的迹象。循环扫描(单 向扫描):从最外向最里进行柱面请求处理,到最里柱面后,直接跳到最外柱面然后继续向里进行处理。该算法与扫描算法的区别是 ,回来过程不处理请求,基于这样的事实,因为里端刚被处理。 2. 实验方法 1)使用流程图描述演示程序的设计思想; 2)选取c/c++、Java等计算机语言,编程调试,最终给出运行正确的程序。

相关文档