




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、学号 P1514032 专业计算机科学与技术姓名实验日期 2017.12.7教师签字 成绩实验名称】磁盘调度(二)【实验目的】磁盘调度中寻道时间直接影响到数据访问的快慢,处理好磁盘寻道时间是关键。分别 米用扫描策略、循环扫描策略处理。【实验原理】1. 扫描算法(SCAh算法)SCAN算法,也就是很形象的电梯调度算法。先按照一个方向(比如从外向内扫描), 扫描的过程中依次调度经过的磁道。当扫描到最里层的一个磁道时反向扫描直至所有磁 道都被调度。2. 循环扫描算法(CSCAI算法)CSCAN算法,循环扫描算法,它的思想是,访问完最里面一个要求服务的序列之后, 从最外层的序号开始往里走。也就是始终保
2、持一个方向,故称为循环扫描算法。【数据结构和符号说明】(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 sort1()
3、/ 从小到大排序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算 法:CSCAI算法(与SCAN算法基本类似):代
4、码:#include#define N 100typedef struct Trackint 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; inum; i+)tracki.state=-1;/id 置为 1track1i.state=-1;stepi=-1;/ 移动距离为 -1void input()/ 输入函数pr
5、intf( 输入当前磁道 n);scanf(%d,¤t_track);num1=current_track;printf( 输入要访问的磁道数目 n);scanf(%d,&num);printf( 输入要访问磁道序列 n);for(i=0; inum; i+)scanf(%d,&tracki.id);void FCFS()/ 先来先服务for(i=0; inum; i+)求移动距离取绝对值if(current_track-tracki.id)0?a-b:b-a;int Serch_min_pos()/ 寻找到当前磁道最短的需求磁道int min=45536;/ 最小距离标志int
6、pos;for(int i=0; iabs(tracki.id,current_track)/min=abs(tracki.id,current_track);pos=i;trackpos.state=1;return pos;/ 返回在数组中的位置void SSTF()/ 最短寻道优先for(i=0; inum; i+)/ 计数器track1i=trackSerch_min_pos();/ 更新到要输出的数组中 stepi=abs(track1i.id,current_track);/ 移动距离 current_track= track1i.id;/ 标志printf(nnn,numl);p
7、rintf(=n);/ 排班 printf( 被访问的下一个磁道 tt 移动距离(磁道数) n);for(i=0; inum; i+)printf(t%4dtt|t%4dn,ai.id,stepi);printf(=n); void output_average_track()/ 输出平均寻道时间double sum=0;/ 和for(i=0; inum; i+)printf(sum+=stepi;平均寻道长度 %3.2fnnn,sum/num);/ 输出int show()/ 显示用户界面int choose;/ 选择printf(n*早期的磁盘调度算法*n);printf(tt1 、先来先
8、服务 (FCFS)n);printf(tt2、最短寻道时间优先( SSTF)n);printf(tt3、退出( EXIT) n);scanf(%d,&choose);return choose;int main()doinit();case 1:/FCFSinput();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)
9、;return 0;截图:主界面开始,输入选择先来先服务还是最短寻道优先, 输入当前磁道, 输入要访问的磁道, 输入要访问的磁道序列。SCAN算法输入 当前磁道 100 ,9 个磁道,分别为 55 58 39 18 90 160 150 38 184 ,此时选择方 向向上结果正确。输入 当前磁道 100 ,9 个磁道,分别为 55 58 39 18 90 160 150 38 184 ,此时选择方 向向下结果正确。CSCAI算法输入 当前磁道 100 ,9 个磁道,分别为 55 58 39 18 90 160 150 38 184 ,此时选择方 向向上结果正确。输入 当前磁道 100 ,9 个
10、磁道,分别为 55 58 39 18 90 160 150 38 184 ,此时选择方 向向上结果正确。【小结与讨论】1、扫描算法又称为电梯算法,其原理与电梯运行情况相似,即运行方向上的请求优先,若 是访问方向向上,则先依次访问较大的磁道号至顶,再向下访问娇小的磁道号;若是访问 方向向下,则先依次访问较小的磁道号至底,再向上访问娇大的磁道号。2、循环扫描算法又称为单向电梯算法,若是访问方向向上,则向上依次访问完较大的磁道 号后,返回最低端,依次向上访问较小的磁道号;若是访问方向向下,则向下依次访问完 较小的磁道号后,返回最顶端,依次向下访问较大的磁道号。3、此次实验我用两个数组分别存放了一个磁道表和复制的磁道表,根据两个算法的原理, 只要将其进行排序,然后分别对两个数组进行正向和逆向的访问即可。4、具体实现时,我将两种算法的两种初始扫描方向写在了一个函数之中,调用时通过参数 scan 和参数 up_or_down 设置。并设置了寻找大于当前数组的最近最小值和最近的大值进 行选择结果,这是因为初始磁道号将磁道数组分成上下(高低地址)两块,这两块根据不 同的扫描方向重新选择高低地址,又结合不同的算
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 水到哪里去了 教学设计-2024-2025学年科学三年级上册教科版
- 全国人教版初中信息技术八年级下册第一单元第3课《作点》教学设计
- 班轮运输标准合同5篇
- 2025年回转换热干燥技术与设备合作协议书
- 小学信息技术三年级上册第7课《玩打字游戏》教学设计
- 13美丽的冬天(教学设计)-部编版道德与法治一年级上册
- 高中信息技术粤教版必修教学设计 3.2.2 建立表格-
- 2025年电动车极板项目可行性研究报告
- 小学信息技术六年级上册第2课《让海龟画图》教学设计
- 2025年制售火柴项目投资可行性研究分析报告
- 期刊创建实施方案
- 人工智能教育2024年AI助力教育教学模式创新
- 水泥厂化验室安全培训课件
- 机械制图自编教材
- 前列腺穿刺的护理查房课件
- 管理会计 课件 孙茂竹 第1-6章 管理会计概论-经营决策
- 《新时期产业工人队伍建设改革方案》全文
- 智能制造行业市场竞争力分析
- 轻钢别墅-建筑流程
- 2023云南公务员考试《行测》真题(含答案及解析)【可编辑】
- 脾破裂护理查房
评论
0/150
提交评论