操作系统专业课程设计磁盘调度算法.doc
《操作系统专业课程设计磁盘调度算法.doc》由会员分享,可在线阅读,更多相关《操作系统专业课程设计磁盘调度算法.doc(30页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、前 言摘要:本课程设计目标是经过设计一个磁盘调度模拟系统,从而使磁盘调度算法愈加形象化,使磁盘调度特点更简单明了,这里关键实现磁盘调度四种算法,分别是:1、先来先服务算法(FCFS) 2、最短寻道时间优先算法(SSTF) 3、扫描算法(SCAN) 4、循环扫描算法(CSCAN)。 开启磁盘实施输入输出操作时,要把移动臂移动到指定柱面,再等候指定扇区旋转到磁头位置下,然后让指定磁头进行读写,完成信息传送;所以,实施一次输入输出所花时间有: 寻求时间磁头在移动臂带动下移动到指定柱面所花时间。 延迟时间指定扇区旋转到磁头下所需时间。 传送时间由磁头进程读写完成信息传送时间,寻道时间指计算机在发出一个
2、寻址命令,到对应目标数据被找到所需时间;其中传送信息所花时间,是在硬件设计时固定,而寻求时间和延迟时间是和信息在磁盘上位置相关;然后设计出磁盘调度设计方法,包含算法思绪、步骤,和要用到关键数据结构、函数模块及其之间调用关系等,并给出具体算法设计,对编码进行了测试和分析。 最终进行个人总结和设计体会。关键词:最短寻道时间优先算法、扫描算法、总寻道长度.目 录前 言22. 课程设计任务及要求42.1 设计任务42.2 设计要求43. 算法及数据结构53.1算法总体思想(步骤)53.2 实现过程中用到数据结构63.3 实现过程中用到系统调用114. 程序设计和实现114.1 最短寻道时间优先算法(S
3、STF)模块114.1.1程序步骤图114.1.2 程序说明134.1.3 程序关键代码134.2扫描算法(SCAN)模块144.2.1 程序步骤图144.2.2 程序说明164.2.3 程序关键代码164.3 试验结果175. 结论266. 参考文件267. 收获、体会和提议272. 课程设计任务及要求2.1 设计任务 1.熟悉并掌握磁盘调度算法管理系统设计方法,加强对所学多种调度算法及对应算法特点了解。 2.掌握磁盘调度基础概念,深刻体会各个算法优缺点,和算法间相同点。 2.2 设计要求 1)定义和算法相关数据结构,如PCB、队列等;2) 实现2种不一样调度算法(可使用伪代码或步骤图进行分
4、析);3) 算法实施结束时,应给出总寻道长度;4) 磁道访问序列随机生成,且要满足一定数量要求(不少于100个);5)系统实现必需提供一定交互性,所需测试数据应该以文件形式提供或由用户在测试过程中给出,不可将测试数据“写死”在系统实现代码中;6)必需给出足够注释,注释量不得少于代码量二分之一;7)对于系统中所使用到系统调用(API函数),必需给出函数定义原型、使用方法,参数较为复杂,还应该给出参数具体描述;3. 算法及数据结构 3.1算法总体思想(步骤) 开始输入磁道个数生成随机磁道号用户输入所选择算法进行磁盘调度输入数字为1-2?输出排序后磁盘序列用户输入目前磁道号显示磁盘调度次序输入为3?
5、退出程序 结束总步骤图 Y N Y N 3.2 实现过程中用到数据结构 1.最短寻道时间优先(SSTF)(从100号磁道开始)被访问下一个磁道号移动距离(磁道数)5545583391918219072160701501038112184146平均寻道长度:55.3 图a SSTF调度算法示例图ciidao=55,58,39,18,90,160,150,38,184(可随机生成多个)用户输入目前磁道号now,比较目前磁道到每个磁道移动距离,选择最短距离磁道进行移动。now指向目前磁道号,计算寻道长度sum。用冒泡法对磁道数组进行排序 返回内侧(外侧)扫描 将目前磁道号和剩下没有访问磁道号进行比较
6、,反复上述操作。并计算平均寻道长度ave。 图b SSTF算法步骤示例图原磁道号随机组成数组:cidao=55,58,39,18,90,160,150,38,184;排序后数组=18,38,39,5,58,90,150,160,184;输入目前磁道号:now=100; 38 39 39 55 55 55 58 58 58 58 90 90 90 90 90now值:100 90 58 55 39 184 160 160 150 150 150 18 18 18 18 38 38 38 38 39 39 39 39 55 55 55 55 58 58 58 58 90 90 90 90 now值
7、:18 150 160 184 图c SSTF算法队列示意图(按磁道访问次序)2.扫描(SCAN)算法(从100号磁道开始,向磁道号增加方向访问)被访问下一个磁道号移动距离(磁道数)1505016010184249094583255339163811820平均寻道长度:27.8 图d SCAN算法示例图原磁道号随机组成数组:cidao=55,58,39,18,90,160,150,38,184;排序后数组=18,38,39,5,58,90,150,160,184;输入目前磁道号:now=100;选择磁道移动方向;以磁道号增加方向移动为例: 55 58 58 90 90 90 184 184 1
8、84 184 160 160 160 160 160 150 150 150 150 150 150now值:100 150 160 184 90 58 18 38 38 39 39 39 55 55 55 58 58 58 90 90 90 184 184 184 160 160 160 150 150 150 now值:55 39 38 图e SCAN算法队列示意图(按磁道访问次序) 3.3 实现过程中用到系统调用系统模块调用关系图磁盘调度算法模拟系统最短寻道时间优先扫描算法退出 4. 程序设计和实现 4.1 最短寻道时间优先算法(SSTF)模块 4.1.1程序步骤图输入磁道号串用冒泡法将
9、磁道号从大到小排序判定now大小调用SSTF()函数输入目前磁道号now开始结束优先服务离now最近 磁道移动方向,再掉头服务计算总寻道长度,并输出移动平均寻道长度直接从大到小给磁道服务直接从小到大给磁道服务找到离now寻道时间最短磁道now=cidao0 cidao0now=cidaom-14.1.2 程序说明算法分析 优点:相较于先来先服务算法(FCFS)有愈加好寻道性能,使每次寻道时间最短。 缺点:易造成某个进程发生“饥饿”现象。 最短寻求时间优先调度算法总是从等候访问者中挑选寻求时间最短那个请求先实施,而不管访问者到来前后次序。比如,假如现在读写磁头正在100号柱面上实施输出操作,而等
10、候访问者依次要访问柱面为55,58,39,18,90,160,150,38,184,那么,当100号柱面操作结束后,应该先处理90号柱面请求,然后抵达58号柱面实施操作,随即处理55号柱面请求,后继操作次序应该是39,38,18,150,160,184.采取最短寻求时间优先算法决定等候访问者实施操作次序时,读写磁头总共移动多个柱面距离,和先来先服务、算法比较,大幅度地降低了寻求时间,含有愈加好寻道性能,所以缩短了为各访问者请求服务平均时间,也就提升了系统效率。但最短查找时间优先(SSTF)调度,FCFS会引发读写头在盘面上大范围移动,SSTF查找距离磁头最短(也就是查找时间最短)请求作为下一次
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 专业课程 设计 磁盘 调度 算法
限制150内