




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验六 磁盘调度算法1、 实验目的通过这次实验,加深对磁盘调度算法的理解,进一步掌握先来先服务FCFS、最短寻道时间优先SSTF、SCAN和循环SCAN算法的实现方法。2、 试验内容问题描述:设计程序模拟先来先服务FCFS、最短寻道时间优先SSTF、SCAN和循环SCAN算法的工作过程。假设有n个磁道号所组成的磁道访问序列,给定开始磁道号m和磁头移动的方向(正向或者反向),分别利用不同的磁盘调度算法访问磁道序列,给出每一次访问的磁头移动距离,计算每种算法的平均寻道长度。3、 程序要求:1)利用先来先服务FCFS、最短寻道时间优先SSTF、SCAN和循环SCAN算法模拟磁道访问过程。2)模拟四种
2、算法的磁道访问过程,给出每个磁道访问的磁头移动距离。3)输入:磁道个数n和磁道访问序列,开始磁道号m和磁头移动方向(对SCAN和循环SCAN算法有效),算法选择1-FCFS,2-SSTF,3-SCAN,4-循环SCAN。4)输出:每种算法的平均寻道长度。4、 需求分析(1) 输入的形式和输入值的范围算法选择要访问的磁道数磁道当前磁道号输入当前移动臂的移动的方向(第三个算法)(2) 输出的形式每种算法的平均寻道长度(3) 测试用例先来先服务FCFS最短寻道时间优先SCAN算法 CSCAN5、 调试分析通过对这次操作系统实验,使我懂得了操作系统磁盘调度的四种算法:先来先服务算法(FCFS)、最短寻
3、道时间优先算法(SSTF)、扫描算法(SCAN)和循环扫描算法(CSCAN)。加深了我对这门课程的理解。锻炼了自己在考虑全局也不是细节的能力。通过这次实验,再一次熟悉并深入掌握了程序设计语言和算法设计。6、 测试结果(1) 使用FCFS算法输入输出(2) 使用SSTF算法输入输出(3) 使用SCAN算法(向增长方向)输入输出(4) 使用SCAN算法(向减少方向)输入输出(5) 使用CSCAN算法输入输出7、 附录(java)package experiment;import java.io.BufferedInputStream;import java.io.FileInputStream;i
4、mport java.io.FileNotFoundException;import java.util.Scanner;public class F_Disc_Dispatch private static int maxsize = 100;/ 要访问的磁道数private static int count;/ 磁道private static int cidao = new intmaxsize;/ 当前磁道号private static int now;/ 总寻道长度private static int sum = 0;/ 平均寻道长度private static double Ave
5、rageDistance;/ 当前移动臂的移动的方向 (1 (true)表示向外 ,0(false)表示向内)private static boolean direction;/ 算法选择/ 1-使用FCFS算法/ 2-使用SSTF算法/ 3-使用SCAN算法/ 4-使用CSCAN算法private static int option = 0;/ for循环用到变量private static int i;private static int j;private static int k;private static Scanner stdin;public static void main(
6、String args) throws FileNotFoundException / 输入数据input();/ int a;switch (option) case 1: / 使用FCFS算法FCFS();break;case 2: / 使用SSTF算法SSTF();break;case 3: / 使用SCAN算法SCAN();break;case 4: / 使用CSCAN算法CSCAN();break;/ 输入数据public static void input() throws FileNotFoundException BufferedInputStream in = new Buf
7、feredInputStream(new FileInputStream("./file/06");System.setIn(in);stdin = new Scanner(System.in);/ 算法选择/ 1-使用FCFS算法/ 2-使用SSTF算法/ 3-使用SCAN算法/ 4-使用CSCAN算法option = stdin.nextInt();/ 要访问的磁道数count = stdin.nextInt();/ 磁道for (i = 0; i < count; i+) cidaoi = stdin.nextInt();/ 当前磁道号now = stdin.n
8、extInt();if (option = 3) / 输入当前移动臂的移动的方向 (1 表示向外 ,0表示向内) :try int g = stdin.nextInt();if (g = 1) direction = true; else direction = false; catch (Exception e) / TODO: handle exceptionSystem.out.println("direction没有正确输入");return;stdin.close();/* 先来先服务调度算法 */public static void FCFS() sum +=
9、Math.abs(cidao0 - now);System.out.print("磁盘扫描序列为:");for (i = 0; i < count; i+) / 输出磁盘扫描序列System.out.print(cidaoi + " ");for (i = 0, j = 1; j < count; i+, j+) / 求平均寻道长度sum += Math.abs(cidaoj - cidaoi);AverageDistance = (float) (sum) / (float) (count);System.out.println("
10、;");System.out.println("平均寻道长度:" + AverageDistance);/* 最短寻道时间优先调度算法 */public static void SSTF() k = 1;int l, r;bubble(); / 调用冒泡排序算法排序if (cidaocount - 1 <= now) / 若当前磁道号大于请求序列中最大者,则直接由外向内依次给予各请求服务System.out.print("磁盘扫描序列为:");for (i = count - 1; i >= 0; i-) System.out.pr
11、int(cidaoi + " ");sum = now - cidao0;if (cidao0 >= now) / 若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务System.out.print("磁盘扫描序列为:");for (i = 0; i < count; i+) System.out.print(cidaoi + " ");sum = cidaocount - 1 - now;if (now > cidao0 && now < cidaocount - 1) / 若
12、当前磁道号大于请求序列中最小者且小于最大者System.out.print("磁盘扫描序列为:");while (cidaok < now) / 确定当前磁道在已排的序列中的位置,后面的算法都用到了,可以直接复制后少量修改,节省时间。k+;l = k - 1;r = k;while (l >= 0) && (r < count) / 当前磁道在请求序列范围内if (now - cidaol) <= (cidaor - now) / 选择与当前磁道最近的请求给予服务System.out.print(cidaol + " &qu
13、ot;);sum += now - cidaol;now = cidaol;l = l - 1; else System.out.print(cidaor + " ");sum += cidaor - now;now = cidaor;r = r + 1;if (l = -1) / 磁头移动到序列的最小号,返回外侧扫描仍未扫描的磁道for (j = r; j < count; j+) System.out.print(cidaoj + " ");sum += cidaocount - 1 - cidao0; else / 磁头移动到序列的最大号,返
14、回内侧扫描仍未扫描的磁道for (j = l; j >= 0; j-) System.out.print(cidaoj + " ");sum += cidaocount - 1 - cidao0;AverageDistance = (float) (sum) / (float) (count);System.out.println("");System.out.println("平均寻道长度: " + AverageDistance);/* 扫描调度算法 */public static void SCAN() / 先要给出当前磁
15、道号和移动臂的移动方向k = 1;int l, r;bubble(); / 调用冒泡排序算法排序if (cidaocount - 1 <= now) / 若当前磁道号大于请求序列中最大者,则直接由外向内依次给予各请求服务,此情况同最短寻道优先System.out.print("磁盘扫描序列为:");for (i = count - 1; i >= 0; i-) System.out.print(cidaoi + " ");sum = now - cidao0;if (cidao0 >= now) / 若当前磁道号小于请求序列中最小者,则
16、直接由内向外依次给予各请求服务,此情况同最短寻道优先System.out.print("磁盘扫描序列为:");for (i = 0; i < count; i+)System.out.print(cidaoi + " ");sum = cidaocount - 1 - now;if (now > cidao0 && now < cidaocount - 1) / 若当前磁道号大于请求序列中最小者且小于最大者while (cidaok < now) k+;l = k - 1;r = k;if (direction =
17、 false) / 选择移动臂方向向内,则先向内扫描System.out.print("磁盘扫描序列为:");for (j = l; j >= 0; j-) System.out.print(cidaoj + " "); / 输出向内扫描的序列for (j = r; j < count; j+) / 磁头移动到最小号,则改变方向向外扫描未扫描的磁道System.out.print(cidaoj + " "); / 输出向外扫描的序列sum = now - 2 * cidao0 + cidaocount - 1; else
18、/ 选择移动臂方向向外,则先向外扫描System.out.print("磁盘扫描序列为:");for (j = r; j < count; j+) System.out.print(cidaoj + " "); / 输出向外扫描的序列for (j = l; j >= 0; j-) / 磁头移动到最大号,则改变方向向内扫描未扫描的磁道System.out.print(cidaoj + " ");sum = -now - cidao0 + 2 * cidaocount - 1;AverageDistance = (float)
19、 (sum) / (float) (count);System.out.println("");System.out.println("平均寻道长度: " + AverageDistance);/* 循环扫描调度算法 */public static void CSCAN() k = 1;int l, r;bubble(); / 调用冒泡排序算法排序if (cidaocount - 1 <= now) / 若当前磁道号大于请求序列中最大者,则直接将移动臂移动到最小号磁道依次向外给予各请求服务System.out.print("磁盘扫描序列为
20、:");for (i = 0; i < count; i+) System.out.print(cidaoi + " ");sum = now - 2 * cidao0 + cidaocount - 1;if (cidao0 >= now) / 若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务,此情况同最短寻道优先System.out.print("磁盘扫描序列为:");for (i = 0; i < count; i+)System.out.print(cidaoi + " ");sum = cidaocount - 1 - now;if (now > cidao0 && now < cidaocount - 1) / 若当前磁道号大于请求序列中最小者且小于最大者System.out.print("磁盘扫描序列为:");while (cidaok < now) / 单向反复地从内向外扫描k+;l = k - 1;r = k;for (j = r; j < count; j+) System.out.print(cid
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 影视音乐版权独家代理授权与版权保护合同
- 美食烹饪自媒体工作室合伙人内容创作与广告合作协议
- 数字孪生城市规划与设计咨询服务协议
- 幼儿园大班音乐活动《小种子》全攻略
- 《事故伤害的防范与应对》课件
- 食堂运营团队管理规划
- ISO 17025实验室管理体系培训
- 医学检验年度总结
- 《公路路面维护与管理》课件
- 《慢性肾小球肾炎》课件
- 高原疾病急救培训课件
- 唐代文学中的植物书写研究
- 《为什么学生不喜欢上学》读后感(通用)
- 2022年中原工学院工作人员招聘考试试题及答案
- 三年级道德与法治下册 (请到我的家乡来)教学课件
- 县中药材协会章程
- 2023年国家司法考试试卷二(真题及答案)
- 第三单元(知识清单)- 高二语文选择性必修下册同步备课系列(统编版)
- 2023学年完整公开课版关于孝
- 头颈面部创伤口评估与处理
- 中医诊所卫生技术人员名录表
评论
0/150
提交评论