data:image/s3,"s3://crabby-images/68dcd/68dcd9986835c166f61e46391853c551a6e205a8" alt="(第五讲磁盘调度算法)_第1页"
data:image/s3,"s3://crabby-images/93a99/93a998607b8f6bb830be94790a414a59bb01f464" alt="(第五讲磁盘调度算法)_第2页"
data:image/s3,"s3://crabby-images/01ffe/01ffe3f29943724b550ff5de48bed895bfd9e278" alt="(第五讲磁盘调度算法)_第3页"
data:image/s3,"s3://crabby-images/da1fc/da1fcebdfbc113edfef7d452083d4b48eb383f7f" alt="(第五讲磁盘调度算法)_第4页"
data:image/s3,"s3://crabby-images/07675/07675ac96d39df1a64844a9cf30b919b3c65af30" alt="(第五讲磁盘调度算法)_第5页"
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、操作系统实验报告课程名称操作系统实验实验项目名称磁盘调度算法学号2010061304班级20100613姓名王鸿运专业计算机学生所在学院计算机科学与技术指导教师王红滨实验室名称地点计算机基础第七实验室哈尔滨工程大学计算机科学与技术学院一、实验概述1. 实验名称 磁盘调度算法2. 实验目的(1) 通过学习 EOS 实现磁盘调度算法的机制, 掌握磁盘调度算法执行的条 件和时机。(2) 观察EOS实现的FCFS、SSTF和SCAN磁盘调度算法,了解常用的 磁盘调度算法。( 3)编写 CSCAN 和 N-Step-SCAN 磁盘调度算法,加深对各种扫描算法 的理解。3. 实验类型 验证,设计4. 实验
2、内容( 1)准备实验(2) 验证先来先服务(FCFS)磁盘调度算法(3) 验证最短寻道时间优先(SSTF)磁盘调度算法(4) 验证 SSTF 算法造成的线程“饥饿”现象(5.1) 验证扫描(SCAN)磁盘调度算法(5.2) 验证 SCAN 算法能够解决“饥饿”现象( 6 ) 改写 SCAN 调度算法二、实验环境EOS 操作系统与 IDE 环境组成的“操作系统集成实验环境 OS Lab ”。三、实验过程(一)实验问题及解答1. 实验指导P176-3.2验证先来先服务(FCFS)磁盘调度算法,要求请给出 在“输出”窗口中的结果。答:输出结果复制如下:制作软盘镜像 .正在启动 Virtual PC.
3、开始调试.* Disk schedule start working *Start Cylinder: 10TID: 31 Cylinder: 8 Offset: 2 -TID: 32 Cylinder: 21 Offset: 13 +TID: 33 Cylinder: 9 Offset: 12 -TID: 34 Cylinder: 78 Offset: 69 +TID: 35 Cylinder: 0 Offset: 78 -TID: 36 Cylinder: 41 Offset: 41 +TID: 37 Cylinder: 10 Offset: 31 -TID: 38 Cylinder: 6
4、7 Offset: 57 +TID: 39 Cylinder: 12 Offset: 55 -Total offset: 360 Transfer times: 10 Average offset: 362. 实验指导P177-3.3验证验证最短寻道时间优先(SSTF)磁盘调度算法, 要求请给出在“输出”窗口中的结果。答:输出结果复制如下:制作软盘镜像 .正在启动 Virtual PC.开始调试.* Disk schedule start working *Start Cylinder: 10TID: 37 Cylinder: 10 Offset: 0 =TID: 40 Cylinder: 1
5、0 Offset: 0 =TID: 33 Cylinder: 9 Offset: 1 -TID: 31 Cylinder: 8 Offset: 1 -TID: 39 Cylinder: 12 Offset: 4 +TID: 32 Cylinder: 21 Offset: 9 +TID: 38 Cylinder: 67 Offset: 26 +TID: 34 Cylinder: 78 Offset: 11 +TID: 35 Cylinder: 0 Offset: 78 -Total offset: 150 Transfer times: 10 Average offset: 153. 实验指导
6、P178-3.4 验证 SSTF 算法造成的线程“饥饿”现象,要求请给 出在“输出”窗口中的结果。答:输出结果复制如下:制作软盘镜像 .正在启动 Virtual PC.开始调试 .* Disk schedule start working *Start Cylinder: 10TID: 37 Cylinder: 10 Offset: 0 =TID: 40 Cylinder: 10 Offset: 0 =TID: 33 Cylinder: 9 Offset: 1 -TID: 34 Cylinder: 8 Offset: 1 -TID: 32 Cylinder: 21 Offset: 9 +TID
7、: 36 Cylinder: 41 Offset: 20 +TID: 38 Cylinder: 67 Offset: 26 +TID: 31 Cylinder: 78 Offset: 11 +Total offset: 72 Transfer times: 10 Average offset: 74. 实验指导 P179-3.5 验证扫描( SCAN )磁盘调度算法, 要求在非饥饿 (即 实验指导 P176-3.2 节中的数据)和饥饿(即实验指导 P178-3.4 节中的 数据)请给出在“输出”窗口中的结果,并且要求在每次输入两次“ds”命令(注 意不要连续输入,要等第一次“ ds ”命令执行
8、完,再输入第二次“ ds ”命令), 分析结果为什么不同。答:输出结果复制如下:( 1 )非饥饿状态,两次输入 ds 指令制作软盘镜像 .正在启动 Virtual PC.开始调试 .* Disk schedule start working *Start Cylinder: 10TID: 37 Cylinder: 10 Offset: 0 =TID: 40 Cylinder: 10 Offset: 0 =TID: 39 Cylinder: 12 Offset: 2 +TID: 32 Cylinder: 21 Offset: 9 +TID: 36 Cylinder: 41 Offset: 20
9、+TID: 38 Cylinder: 67 Offset: 26 +TID: 34 Cylinder: 78 Offset: 11 +TID: 33 Cylinder: 9 Offset: 69 -TID: 31 Cylinder: 8 Offset: 1 -TID: 35 Cylinder: 0 Offset: 8 -Total offset: 146 Transfer times: 10 Average offset: 14 * Disk schedule stop working * Disk schedule start working *Start Cylinder: 10TID:
10、47 Cylinder: 10 Offset: 0 =TID: 41 Cylinder: 8 Offset: 1 -TID: 45 Cylinder: 0 Offset: 8 -TID: 49 Cylinder: 12 Offset: 12 +TID: 42 Cylinder: 21 Offset: 9 +TID: 46 Cylinder: 41 Offset: 20 +TID: 48 Cylinder: 67 Offset: 26 +TID: 44 Cylinder: 78 Offset: 11 +Total offset: 88 Transfer times: 10 Average off
11、set: 82)饥饿状态,两次输入 ds 指令制作软盘镜像 .正在启动 Virtual PC.开始调试 .* Disk schedule start working *Start Cylinder: 10TID: 37 Cylinder: 10 Offset: 0 =TID: 40 Cylinder: 10 Offset: 0 =TID: 35 Cylinder: 11 Offset: 1 +TID: 39 Cylinder: 12 Offset: 1 +TID: 32 Cylinder: 21 Offset: 9 +TID: 36 Cylinder: 41 Offset: 20 +TID:
12、38 Cylinder: 67 Offset: 26 +TID: 31 Cylinder: 78 Offset: 11 +TID: 33 Cylinder: 9 Offset: 69 -TID: 34 Cylinder: 8 Offset: 1 -Total offset: 138 Transfer times: 10 Average offset: 13* Disk schedule stop working * Disk schedule start working *Start Cylinder: 10TID: 47 Cylinder: 10 Offset: 0 =TID: 50 Cyl
13、inder: 10 Offset: 0 =TID: 43 Cylinder: 9 Offset: 1 -TID: 44 Cylinder: 8 Offset: 1 -TID: 45 Cylinder: 11 Offset: 3 +TID: 46 Cylinder: 41 Offset: 20 +TID: 48 Cylinder: 67 Offset: 26 +TID: 41 Cylinder: 78 Offset: 11 +Total offset: 72 Transfer times: 10 Average offset: 7分析两次结果为何不同:执行完一次 ds 命令后,该次搜索的指针方向
14、被保 存,但是和初始值相比,搜索的方向发生了变化。根据 SCAN 算法,按一个方 向访问磁盘,一个方向访问到尽头后再换一个方向继续访问。下次访问, 按上次 访问结束时的方向继续访问。 于是第二次访问的方向会与第一次不同, 造成两次 DS 命令输出的结果不同。(二)实验代码及解释实验结果:制作软盘镜像 .正在启动 Virtual PC.开始调试 .* Disk schedule start working *Start Cylinder: 10TID: 37 Cylinder: 10 Offset: 0 =TID: 39 Cylinder: 12 Offset: 2 +TID: 32 Cylin
15、der: 21 Offset: 9 +TID: 36 Cylinder: 41 Offset: 20 +TID: 38 Cylinder: 67 Offset: 26 +TID: 34 Cylinder: 78 Offset: 11 +TID: 33 Cylinder: 9 Offset: 69 -TID: 31 Cylinder: 8 Offset: 1 -TID: 35 Cylinder: 0 Offset: 8 -Total offset: 146 Transfer times: 10 Average offset: 14* Disk schedule stop working * Di
16、sk schedule start working *Start Cylinder: 10TID: 47 Cylinder: 10 Offset: 0 =TID: 50 Cylinder: 10 Offset: 0 =TID: 43 Cylinder: 9 Offset: 1 -TID: 49 Cylinder: 12 Offset: 12 +TID: 42 Cylinder: 21 Offset: 9 +TID: 46 Cylinder: 41 Offset: 20 +TID: 48 Cylinder: 67 Offset: 26 +TID: 44 Cylinder: 78 Offset:
17、11 +Total offset: 88 Transfer times: 10 Average offset: 8 源代码:PREQUESTIopDiskSchedule(VOID)PLIST_ENTRY pListEntry;PREQUEST pRequest;LONG Offset;ULONG InsideShortestDistance = 0xFFFFFFFF;ULONG OutsideShortestDistance = 0xFFFFFFFF;PREQUEST pNextRequest0 =NULL,pNextRequest1=NULL,pNextRequest2=NULL;/ 需要
18、遍历请求队列一次或两次/for (pListEntry = RequestListHead.Next;/ 请求队列中的第一个请求是链表头指向的下一个请求。pListEntry != &RequestListHead;/ 遍历到请求队列头时结束循环。pListEntry = pListEntry-Next) / 根据链表项获得请求的指针/pRequest = CONTAINING_RECORD(pListEntry, REQUEST,ListEntry);/ 计算请求对应的线程所访问的磁道与当前磁头所在磁道的偏移 方向由正负表示)/Offset = pRequest-Cylinder - CurrentCylinder;if (0 = Offset) / 如果线程要访问的磁道与当前磁头所在磁道相同,可立即返回/pNextRequest0 = pRequest;return pNextRequest0; if (Offset 0) / 记录向内移动距离最短的线程/if (Offset InsideShortestDistance) InsideShortestDistance = Offset; pNextRequest1 = pRequest; if ( Offset 0) / / 记录向外移动距离最短的线程/if (-Offset OutsideShortestDistance)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030年中国除草剂市场运营状况发展趋势分析报告
- 2025-2030年中国锆英砂行业供需现状及投资发展规划研究报告
- 2025-2030年中国连接器制造市场发展动态及前景趋势预测报告
- 2025-2030年中国轮滑鞋行业发展现状及前景趋势分析报告
- 2025-2030年中国血浆增容剂行业运行动态与发展风险评估报告
- 2025-2030年中国葵花油市场运行态势及发展盈利分析报告
- 2025-2030年中国艺术玻璃行业市场运行态势及投资战略研究报告
- 2025-2030年中国管道检测行业供需现状及投资发展规划研究报告
- 2025-2030年中国空冷器市场运行现状及发展策略分析报告
- 2025-2030年中国种衣剂市场运营状况及发展趋势研究报告
- Unit 3 Environmental Protection Reading and Thinking 选择性必修第三册
- 2025年合伙型公司新合伙人加入协议
- 小学道德与法治课堂教学中提升学生核心素养策略
- 中水回用项目可行性研究报告
- 2025城市商铺买卖合同书
- 基于主题式教学法的初级汉语综合课《我的低碳生活》教学设计
- 微信公众号运营及推广合同
- 2025年浙江长兴文旅集团招聘笔试参考题库含答案解析
- 医院临床科研大数据平台方案
- 2024年北京市中考生物真题卷及答案解析
- 2023年凉山州西昌市人民医院招聘卫生专业技术人员考试真题
评论
0/150
提交评论