磁盘调度算法实验报告

上传人:仙*** 文档编号:44871163 上传时间:2021-12-06 格式:DOC 页数:23 大小:590KB
收藏 版权申诉 举报 下载
磁盘调度算法实验报告_第1页
第1页 / 共23页
磁盘调度算法实验报告_第2页
第2页 / 共23页
磁盘调度算法实验报告_第3页
第3页 / 共23页
资源描述:

《磁盘调度算法实验报告》由会员分享,可在线阅读,更多相关《磁盘调度算法实验报告(23页珍藏版)》请在装配图网上搜索。

1、.操作系统实 验 报 告课程名称操作系统实验课程编号0906553实验项目名称磁盘调度算法学号年级姓名专业计算机科学与技术学生所在学院计算机科学与技术学院指导教师实验室名称地点 哈尔滨工程大学计算机科学与技术学院精品.磁盘调度算法一 实验概述:1.实验名称:磁盘调度算法2.实验目的:1)通过学习 EOS 实现磁盘调度算法的机制,掌握磁盘调度算法执行的条件和时机;2)观察 EOS 实现的 FCFS、SSTF 和 SCAN 磁盘调度算法,了解常用的磁盘调度算法;3)编写 CSCAN 和 N-Step-SCAN 磁盘调度算法,加深对各种扫描算法的理解。3.实验类型:验证、设计4.实验内容: 1)准备

2、实验,创建一个EOS Kernel项目; 2)验证先来先服务(FCFS)磁盘调度算法; 3)验证最短寻道时间优先(SSTF)磁盘调度算法; 4)验证SSTF算法造成的线程“饥饿现象”; 5)验证扫描(SCAN)磁盘调度算法; 6)改写SCAN算法; 7)编写循环扫描(CSCAN)磁盘调度算法; 8)验证SSTF、SCAN及CSCAN算法中的“磁臂粘着”现象; 9)编写N-Step-SCAN磁盘调度算法。二实验环境操作系统:windows XP编译器:Tevalaton OS Lab语言:C三实验过程1.设计思路和流程图: SCAN算法流程图: 精品. SSTF算法的流程图: 精品.CSACN流

3、程图:循环结束后记录了向内移动距离最短的线程和向外移动距离最长的线程 有向内移动的线程? YES NO选择向内移动距离最短的线程选择向外移动距离最长的线程N-STEP-SCAN算法调度:2.实验过程:1)新建一个 EOS Kernel 项目;2)在 sysproc.c 文件中找到控制台命令“ds”对应的函数 ConsoleCmdDiskSchedule。“ ds” 命令专门用来测试磁盘调度算法。阅读该函数中的源代码,目前该函数使磁头初始停留在磁道 10, 其它被阻塞的线程依次访问磁道 8、21、9、78、0、41、10、67、12、10;3)打开 io/block.c 文件,在 第 378 行

4、找到磁盘调度算法函数 IopDiskSchedule。阅读该函数中的源代码,目前此函数实现了 FCFS 磁盘调度算法,流程图如下:精品.4)生成项目,启动调试,待 EOS 启动完毕,在 EOS 控制台中输入命令“ds”后按回车;精品.在 EOS 控制台中会首先显示磁头的起始位置是 10 磁道,然后按照线程被阻塞的顺序依次显示线程的 信息(包括线程 ID 和访问的磁道号)。磁盘调度算法执行的过程中,在 OS Lab 的“输出”窗口中也会首 先显示磁头的起始位置,然后按照线程被唤醒的顺序依次显示线程信息(包括线程 ID、访问的磁道号、磁 头移动的距离和方向),并在磁盘调度结束后显示此次调度的统计信

5、息(包括总寻道数、寻道次数和平均 寻道数)。对比 EOS 控制台和“输出”窗口中的内容,可以发现 FCFS 算法是根据线程访问磁盘的先后顺序 进行调度的。下图显示了本次调度执行时磁头移动的轨迹:5)打开sstf.c 文件,该文件提供的 IopDiskSchedule 函数实现了 SSTF 磁盘调度算法,其中应注意:变量 Offset 是有符号的长整型,用来表示磁头的偏移(包括距离和方向)。Offset 大于 0 时表示 磁头向内移动(磁道号增加);小于 0 时表示磁头向外移动(磁道号减少);等于 0 时表示磁头没 有移动。而名称以“Distance”结尾的变量都是无符号长整型,只表示磁头移动的

6、距离(无方向)。 所以在比较磁头的偏移和距离时,或者在将偏移赋值给距离时,都要取偏移的绝对值(调用 C 库 函数 abs)。本实验在实现其它磁盘调度算法时也同样遵守此约定;在开始遍历之前,将最小距离(ShortestDistance)初始化为最大的无符号长整型数,这样,第 一次计算的距离一定会小于最小距离,从而可以使用第一次计算的距离来再次初始化最小距离。 本实验在实现其它磁盘调度算法时也同样使用了此技巧。6)生成项目,启动调试,待EOS 启动完毕,在 EOS 控制台中输入命令“ds”后按回车;对比 EOS 控制台和“输出”窗口中的内容(特别是线程 ID 的顺序),可以发现,SSTF 算法唤醒

7、线程的 顺序与线程被阻塞的顺序是不同的。图18-4显示了本次调度执行时磁头移动的轨迹。对比SSTF算法与FCFS 算法在“输出”窗口中的内容,可以看出,SSTF 算法的平均寻道数明显低于 FCFS 算法。精品.7)验证SSTF算法造成的线程“饥饿现象”,使用 SSTF 算法时,如果不断有新线程要求访问磁盘,而且其所要访问的磁道与当前磁头所在磁道的 距离较近,这些新线程的请求必然会被优先满足,而等待队列中一些老线程的请求就会被严重推迟,从而 使老线程出现“饥饿”现象。8)修改sysproc.c文件ConsoleCmdDiskSchedule函数中的源代码,仍然使磁头初始停留在磁道10,而让其它线

8、程依次访问磁道 78、21、9、8、11、41、10、67、12、10,生成项目,启动调试,待 EOS 启动完毕,在 EOS 控制台中输入命令“ds”后按回车;查看“输出”窗口中显示的内容,可以发现,虽然访问 78 号磁道的线程的请求第一个被放入请求队 列,但却被推迟到最后才被处理,出现了精品.“饥饿”现象。如果不断有新线程的请求到达并被优先满足,则 访问 78 号磁道的线程的“饥饿”情况就会更加严重;修改访问磁道顺序:修改后执行“ds”命令的结果:精品.多次输入“ds”命令:9)对 SSTF 算法稍加改进后可以形成 SCAN 算法,可防止老线程出现“饥饿”现象。打开scan.c 文件,该文件

9、提供的 IopDiskSchedule 函数实现了 SCAN 磁盘调度算法。其中应注意下面几点:在 block.c 文件中的第 374 行定义了一个布尔类型的全局变量 ScanInside,用于表示扫描算法中 磁头移动的方向。该变量值为 TRUE 时表示磁头向内移动(磁道号增加);值为 FALSE 时表示磁头 向外移动(磁道号减少)。该变量初始化为 TRUE,表示 SCAN 算法第一次执行时,磁头向内移动;在 scan.c 文件的 IopDiskSchedule 函数中使用了双重循环。第一次遍历队列时,查找指定方向 上移动距离最短的线程,如果在指定方向上已经没有线程,就变换方向,进行第二次遍历

10、,同样 是查找移动距离最短的线程。在这两次遍历中一定能找到合适的线程。10)使用 scan.c 文件中 IopDiskSchedule 函数的函数体,替换 block.c 文件中 IopDiskSchedule 函 数的函数体,生成项目,启动调试,待 EOS 启动完毕,在 EOS 控制台中输入命令“ds”后按回车;精品.对比 SCAN 算法与 SSTF 算法在“输出”窗口中的内容,可以看出,SCAN 算法的平均寻道数有可能小于 SSTF 算法,所以说 SSTF 算法不能保证平均寻道数最少。下图显示了本次调度执行时磁头移动的轨迹:11)改写SCAN算法,算法提示:精品.在一次遍历中,不再关心当前

11、磁头移动的方向,而是同时找到两个方向上移动距离最短的线程所 对应的请求,这样就不再需要遍历两次;在计算出线程要访问的磁道与当前磁头所在磁道的偏移后,可以将偏移分为三种类型:偏移为 0,表示线程要访问的磁道与当前磁头所在磁道相同,此情况应该优先被调度,可立即返回该线程对应的请求的指针;偏移大于 0,记录向内移动距离最短的线程对应的请求;偏移小于0,记录向 外移动距离最短的线程对应的请求;循环结束后,根据当前磁头移动的方向选择同方向移动距离最短的线程,如果在同方向上没有线 程,就变换方向,选择反方向移动距离最短的线程;流程如下所示:SCAN改写代码:PREQUESTIopDiskSchedule(

12、VOID)PLIST_ENTRY pListEntry;PREQUEST pRequest;PREQUEST INpNextRequest = NULL; PREQUEST OUTpNextRequest = NULL;LONG Offset;ULONG InsideShortestDistance = 0xFFFFFFFF;ULONG OutsideShortestDistance = 0xFFFFFFFF;PREQUEST pNextRequest = NULL;/ 需要遍历请求队列一次或两次 for (pListEntry = RequestListHead.Next;/ 请求队列中的第

13、一个请求是链表头指向的下一个请求。 pListEntry != &RequestListHead;/ 遍历到请求队列头时结束循环。 pListEntry = pListEntry-Next) / 根据链表项获得请求的指针pRequest = CONTAINING_RECORD(pListEntry, REQUEST, ListEntry);/ 计算请求对应的线程所访问的磁道与当前磁头所在磁道的偏移(方向由正负表示)Offset = pRequest-Cylinder - CurrentCylinder;if (0 = Offset) / 如果线程要访问的磁道与当前磁头所在磁道相同,可立即返回。

14、pNextRequest = pRequest;goto RETURN; else if (Offset 0) 精品./ 记录向内移动距离最短的线程InsideShortestDistance = Offset;INpNextRequest = pRequest; else if (-Offset OutsideShortestDistance & Offset Next) / 根据链表项获得请求的指针pRequest = CONTAINING_RECORD(pListEntry, REQUEST, ListEntry);/ 计算请求对应的线程所访问的磁道与当前磁头所在磁道的偏移(方向由正负表

15、示)Offset = pRequest-Cylinder - CurrentCylinder;if (0 = Offset) / 如果线程要访问的磁道与当前磁头所在磁道相同,可立即返回。pNextRequest = pRequest;goto RETURN; else if (Offset 0) / 记录向内移动距离最短的线程InsideShortestDistance = Offset;INpNextRequest = pRequest; else if (-Offset OutsideShortestDistance & Offset 0;/ 遍历到请求队列头时结束循环或子队列结束。 pL

16、istEntry = pListEntry-Next) / 根据链表项获得请求的指针pRequest = CONTAINING_RECORD(pListEntry, REQUEST, ListEntry);/ 计算请求对应的线程所访问的磁道与当前磁头所在磁道的偏移(方向由正负表示)Offset = pRequest-Cylinder - CurrentCylinder;if (0 = Offset) / 如果线程要访问的磁道与当前磁头所在磁道相同,可立即返回。pNextRequest = pRequest;goto RETURN;精品. else if (Offset 0) / 记录向内移动距

17、离最短的线程InsideShortestDistance = Offset;INpNextRequest = pRequest; else if (-Offset OutsideShortestDistance & Offset 0) / 记录向外移动距离最短的线程OutsideShortestDistance = -Offset;OUTpNextRequest = pRequest;counter-;/判断磁头移动方向,若向内移动if(ScanInside) /判断是否有向内移动的线程 if(INpNextRequest) /有则原则该进程 return INpNextRequest; el

18、se /没有则修改磁头方向,选择向外移动距离最短的线程 ScanInside=!ScanInside; return OUTpNextRequest; /如果向外移动else /判断是否有向外移动的线程 if(OUTpNextRequest) /有则选择该进程 return OUTpNextRequest; else /没有则修改磁头的方向,选择向内移动距离最短的线程 ScanInside =!ScanInside; return INpNextRequest; 16)生成项目,启动程序,在控制台中多次输入“ds”命令,查看磁盘调度算法的执行情况。精品.输入“ds”命令进行测试:将宏定义 SUB_QUEUE_LENGTH 的值修改为 100,算法性能接近于 SCAN 算法的性能;将宏定义 SUB_QUEUE_LENGTH 的值修改为 1,算法退化为 FCFS 算法。四实验体会 通过本次实验的具体操作,了解了磁盘调度的SSTF算法、SCAN算法、CSCAN算法以及N-STEP-SCAN算法的具体代码和实现过程,掌握了不同的调度算法的各自特点,并与具体的理论知识相比较与验证,对掌握的理论知识有了更准确的理解。如有侵权请联系告知删除,感谢你们的配合!精品

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!