操作系统实验磁盘调度扫描算法循环扫描算法参考模板_第1页
操作系统实验磁盘调度扫描算法循环扫描算法参考模板_第2页
操作系统实验磁盘调度扫描算法循环扫描算法参考模板_第3页
操作系统实验磁盘调度扫描算法循环扫描算法参考模板_第4页
操作系统实验磁盘调度扫描算法循环扫描算法参考模板_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、学号P1514032 专业 计算机科学与技术 姓名 实验日期2017.12.7 教师签字 成绩实验报告【实验名称】 磁盘调度(二) 【实验目的】 磁盘调度中寻道时间直接影响到数据访问的快慢,处理好磁盘寻道时间是关键。分别采用扫描策略、循环扫描策略处理。【实验原理】 1. 扫描算法(SCAN算法)SCAN算法,也就是很形象的电梯调度算法。先按照一个方向(比如从外向内扫描),扫描的过程中依次调度经过的磁道。当扫描到最里层的一个磁道时反向扫描直至所有磁道都被调度。2.循环扫描算法(CSCAN算法)CSCAN算法,循环扫描算法,它的思想是,访问完最里面一个要求服务的序列之后,从最外层的序号开始往里走。

2、也就是始终保持一个方向,故称为循环扫描算法。【数据结构和符号说明】1 / 10(1) 数据结构和符号说明编译语言:C+数据结构:结构体数组符号定义: typedef struct Track/磁道结构体 int id;/磁道序列 int state=0;/是否访问过,未被访问置状态为0 Track;Track trackN;/最大磁道数为100Track track1N;/复制的磁道数组用于输出int stepN;/移动距离int num,i,current_track,num1; /当前磁道即部分中间变量函数说明:void init()/初始化程序void input()/输入函数void

3、sort1()/从小到大排序int abs(int a,int b)/相减的绝对值int find_first_bignum()/寻找第一个最大值int find_first_smallnum()/寻找第一个最小值void SCAN(int up_or_down) /扫描算法void CSCAN(int up_or_down) /循环扫描算法void output(Track a)/输出函数void output_average_track()/输出平均寻道时间int show()/显示用户界面/返回值为输入的选择项流程图:SCAN算法:CSCAN算法(与SCAN算法基本类似):代码:#inc

4、lude<stdio.h>#define N 100typedef struct Track int id;/磁道序列 int state=0;/是否访问过,未被访问置状态为0 Track;Track trackN;/最大磁道数为100Track track1N;int stepN;/移动距离int num,i,current_track,num1;void init()/初始化程序 num=0; for (i=0; i<num; i+) tracki.state=-1;/id置为1 track1i.state=-1; stepi=-1;/移动距离为-1 void input

5、()/输入函数 printf("输入当前磁道n"); scanf("%d",&current_track); num1=current_track; printf("输入要访问的磁道数目n"); scanf("%d",&num); printf("输入要访问磁道序列n"); for(i=0; i<num; i+) scanf("%d",&tracki.id);void FCFS()/先来先服务 for(i=0; i<num; i+) if(

6、current_track-tracki.id)<0)/求移动距离 stepi=tracki.id-current_track; else stepi=current_track-tracki.id;/取绝对值 tracki.state=1;/状态置为1 current_track=tracki.id;/更新当前磁道 int abs(int a,int b)/相减的绝对值 return a-b>0?a-b:b-a;int Serch_min_pos()/寻找到当前磁道最短的需求磁道 int min=45536;/最小距离标志 int pos; for(int i=0; i<n

7、um; i+) if(tracki.state=1) continue; else if(min>abs(tracki.id,current_track)/寻找最小距离 min=abs(tracki.id,current_track); pos=i; trackpos.state=1; return pos;/返回在数组中的位置void SSTF()/最短寻道优先 for(i=0; i<num; i+)/计数器 track1i=trackSerch_min_pos();/更新到要输出的数组中 stepi=abs(track1i.id,current_track);/移动距离 cur

8、rent_track= track1i.id;/标志 void output(Track a)/输出函数 printf("nn <从%d号磁道开始>n",num1); printf("=n");/排班 printf("被访问的下一个磁道tt移动距离(磁道数)n"); for(i=0; i<num; i+) printf("t%4dtt|t%4dn",ai.id,stepi); printf("=n");void output_average_track()/输出平均寻道时间 d

9、ouble sum=0;/和 for(i=0; i<num; i+) sum+=stepi; printf(" 平均寻道长度%3.2fnnn",sum/num);/输出int show()/显示用户界面 int choose;/选择 printf("n*早期的磁盘调度算法*n"); printf("tt1、先来先服务(FCFS)n"); printf("tt2、最短寻道时间优先(SSTF)n"); printf("tt3、退出(EXIT)n"); scanf("%d",

10、&choose); return choose;int main() do init(); switch(show()/返回值是选择 case 1:/FCFS input(); FCFS(); output(track); output_average_track(); break; case 2:/最短寻道 input(); SSTF(); output(track1); output_average_track(); break; case 3:/退出 return 0; default: break; while(1); return 0;截图:主界面开始,输入选择先来先服务还是

11、最短寻道优先,输入当前磁道,输入要访问的磁道,输入要访问的磁道序列。SCAN算法输入 当前磁道100 ,9个磁道,分别为55 58 39 18 90 160 150 38 184,此时选择方向向上结果正确。输入 当前磁道100 ,9个磁道,分别为55 58 39 18 90 160 150 38 184,此时选择方向向下结果正确。CSCAN算法输入 当前磁道100 ,9个磁道,分别为55 58 39 18 90 160 150 38 184,此时选择方向向上结果正确。 输入 当前磁道100 ,9个磁道,分别为55 58 39 18 90 160 150 38 184,此时选择方向向上结果正确。

12、【小结与讨论】1、扫描算法又称为电梯算法,其原理与电梯运行情况相似,即运行方向上的请求优先,若是访问方向向上,则先依次访问较大的磁道号至顶,再向下访问娇小的磁道号;若是访问方向向下,则先依次访问较小的磁道号至底,再向上访问娇大的磁道号。2、循环扫描算法又称为单向电梯算法,若是访问方向向上,则向上依次访问完较大的磁道号后,返回最低端,依次向上访问较小的磁道号;若是访问方向向下,则向下依次访问完较小的磁道号后,返回最顶端,依次向下访问较大的磁道号。3、此次实验我用两个数组分别存放了一个磁道表和复制的磁道表,根据两个算法的原理,只要将其进行排序,然后分别对两个数组进行正向和逆向的访问即可。4、具体实现时,我将两种算法的两种初始扫描方向写在了一个函数之中,调用时通过参数scan和参数up_or_down设置。并设置了寻找大于当前数组的最近最小值和最近的大值进行选择结果,这是因为初始磁道号将磁道数组分成上下(高低地址)两块

温馨提示

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

评论

0/150

提交评论