操作系统课程设计磁盘调度算法实践

上传人:仙*** 文档编号:34032058 上传时间:2021-10-20 格式:DOC 页数:25 大小:6.64MB
收藏 版权申诉 举报 下载
操作系统课程设计磁盘调度算法实践_第1页
第1页 / 共25页
操作系统课程设计磁盘调度算法实践_第2页
第2页 / 共25页
操作系统课程设计磁盘调度算法实践_第3页
第3页 / 共25页
资源描述:

《操作系统课程设计磁盘调度算法实践》由会员分享,可在线阅读,更多相关《操作系统课程设计磁盘调度算法实践(25页珍藏版)》请在装配图网上搜索。

1、操作系统课程设计磁盘调度算法实践系 院: 信息工程学院学生姓名:耿万德 学 号:0934110135专 业:计算机科学与技术年 级:计科0901B完成日期:2011年12月指导教师:刘栓属性职务姓名学号班级组长耿万德0934110135计科0901B副组长梁光彩0934110149计科0901B成员杨少钶0943110114计科0901B一、课程设计的性质与任务1、加深对磁盘调度算法的理解,通过编程模拟不同磁盘调度算法的流程。2、培养学生能够独立进行知识综合,独立开发较大程序的能力。3、培养提高学生软件开发能力和软件的调试技术。4、培养学生开发大型程序的方法和相互合作的精神。5、培养学生的创新

2、意识。6、培养学生的算法设计和算法分析能力。7、培养学生对问题进行文字论述和文字表达的能力。二、课程设计的内容及其要求1、可利用先来先服务算法(FCFS即first come first served)、最短寻道时间优先算法(SSTF即shortest seek time first)、扫描算法(SCAN)、循环扫描算法(CSCAN),来实现磁盘的访问顺序。2、根据磁盘调度算法的不同的特性做好软件实现的需求分析。3、可根据问题的实际需要,可模拟数据在磁道的存放位置。4、当系统运行时,能直观地、动态地反映当前磁盘状态及不同算法的平均寻道时间。5、要求在系统安全状态的前提下,用户指定需要访问的磁道

3、,软件自动模拟在不同算法情况下,磁盘寻道顺序和平均寻道时间。三、课程设计的时间安排 课程设计总时间:8学时四、课程设计的实验环境硬件环境:CPU Intel(R) Core2 Duo E4600 2.40GHz,内存 DDR2 1.00GB,硬盘 7200转 160G ,光驱 16X DVD 软件环境:Windows XP SP SP3, Visual C+ 6.0 五、正文1、 实验程序的结构图(流程图);先来先服务算法(FCFS)流程图:输入磁道号求平均寻道长度输出移动的平均磁道数按输入顺序将磁道序列输出开始结束 最短寻道时间优先算法(SSTF)流程图: 求平均寻道长度选择与当前磁道距离最

4、近的磁道进行扫描移动到最小(大)号,改向外(内)移动扫描未扫描的磁道输出移动的平均磁道数输出排好序的磁道序列判断当前磁头在序列中的位置结束开始输入磁道号使用冒泡法从小到大排序输入当前磁道号扫描算法(SCAN)流程图:求平均寻道长度选择移动臂移动方向,开始扫描移动到最小(大)号,改向外(内)移动扫描未扫描的磁道输出移动的平均磁道数输出排好序的磁道序列开始结束输入磁道号使用冒泡法从小到大排序输入当前磁道号判断当前磁头在序列中的位置循环扫描算法(CSCAN)流程图:求平均寻道长度扫描到最大号后,直接移动到最小号从内向外扫描未扫描的磁道输出移动的平均磁道数输出排好序的磁道序列判断当前磁头在序列中的位置

5、规定移动臂单向反复的从内向外扫描开始结束输入磁道号使用冒泡法从小到大排序输入当前磁道号2、数据结构及信号量定义的说明;本系统划分为四个模块:先来先服务算法模块void FCFS(int array,int m)、最短寻道时间优先算法模块void SSTF(int array,int m)、扫描算法模块void SCAN(int array,int m) 和循环扫描算法模块:void CSCAN(int array,int m) 。1 先来先服务算法模块:void FCFS(int array,int m)输入磁道号,按先来先服务的策略输出磁盘请求序列,求平均寻道长度,输出移动平均磁道数。2 最

6、短寻道时间优先算法模块:void SSTF(int array,int m)将磁道号用冒泡法从小到大排序,输出排好序的磁道序列,输入当前磁道号,根据前磁道在已排的序列中的位置,选择扫描的顺序,求出平均寻道长度,输出移动的平均磁道数。3 扫描算法模块:void SCAN(int array,int m)将磁道号用冒泡法从小到大排序,输出排好序的序列,输入当前磁道号,选择移动臂的移动方向,根据当前磁道在已排的序列中的位置,选择扫描的顺序,求出平均寻道长度,输出移动的平均磁道数。4 循环扫描算法模块:void CSCAN(int array,int m)将磁道号用冒泡法从小到大排序,输出排好序的序列

7、,输入当前磁道号,规定移动臂单向反复的从内向外移动,根据当前磁道在已排的序列中的位置,选择扫描的顺序,求出平均寻道长度,输出移动的平均磁道数。3、实验的步骤;输入的磁道序列为:12 4 54 7 23 452 141 162 354 21 471 256 45 11 25 3 689 5 241 先来先服务算法当前磁道号:任意(这里取25)平均寻道长度:197.6322 最短寻道时间优先算法(1)当前磁道号大于磁道序列中的最大的磁道号时当前磁道号:890平均寻道长度:46.6482(2)当前磁道号小于磁道序列中的最小的磁道号时当前磁道号:1平均寻道长度:36.2105(3)当前磁道号大于磁道序

8、列中的最小的磁道号且小于最大磁道号时 当前磁道号:255平均寻道长度:49.47373 扫描算法(1)当前磁道号大于磁道序列中的最大的磁道号时当前磁道号:890平均寻道长度:46.6842(2)当前磁道号小于磁道序列中的最小的磁道号时当前磁道号:1平均寻道长度:36.2105(3)当前磁道号大于磁道序列中的最小的磁道号且小于最大磁道号(磁头向外)时当前磁道号:255平均寻道长度:58.9474(4)当前磁道号大于磁道序列中的最小的磁道号且小于最大磁道号(磁头向内)时当前磁道号:255平均寻道长度:49.36844 循环扫描算法(1)当前磁道号大于磁道序列中的最大的磁道号时当前磁道号:890平均

9、寻道长度:82.7895(2)当前磁道号小于磁道序列中的最小的磁道号时当前磁道号:1平均寻道长度:36.2105(3)当前磁道号大于磁道序列中的最小的磁道号且小于最大磁道号时当前磁道号:100平均寻道长度:67.31584、实验源程序关键算法;1先来先服务算法模块:void FCFS(int array,int m)主要代码:for(i=0,j=1;jm;i+,j+) sum+=abs(arrayj-arrayi); ave=(float)(sum)/(float)(m);2 最短寻道时间优先算法模块:void SSTF(int array,int m)主要代码:for(i=0;im;i+)

10、/*使用冒泡法按从小到大顺序排列*/for(j=i+1;jarrayj) temp=arrayi; arrayi=arrayj; arrayj=temp; if(arraym-1=0;i-) coutarrayi=now) /*若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务*/ while(l=0)&(rm) /*当前磁道在请求序列范围内*/ if(now-arrayl)=(arrayr-now) /*选择与当前磁道最近的请求给予服务*/ coutarrayl=0;j-) coutarrayj ; /*输出向内扫描的序列*/ for(j=r;jm;j+) /*磁头移动到最小

11、号,则改变方向向外扫描未扫描的磁道*/ coutarrayj ; /*输出向外扫描的序列*/ sum=now-2*array0+arraym-1; else /*选择移动臂方向向外,则先向外扫描*/ for(j=r;jm;j+) coutarrayj=0;j-) /*磁头移动到最大号,则改变方向向内扫描未扫描的磁道*/ coutarrayj ; sum=-now-array0+2*arraym-1; ave=(float)(sum)/(float)(m);4 循环扫描算法模块:void CSCAN(int array,int m)主要代码:if(arraym-1=now) /*若当前磁道号大于

12、请求序列中最大者,则直接将移动臂移动到最小号磁道依次向外给予各请求服务 */ for(i=0;im;i+) coutarrayi=now) /*若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务,此情况同最短寻道优先*/ for(i=0;im;i+) coutarrayi ; sum=arraym-1-now; for(j=0;jr;j+) /*当扫描完最大号磁道,磁头直接移动到最小号磁道,再向外扫描未扫描的磁道*/ coutarrayj ; sum=2*arraym-1-now; ave=(float)(sum)/(float)(m);5、实验运行图;算法首页1 先来先服务算

13、法2最短寻道时间优先算法(1)当前磁道号大于磁道序列中的最大的磁道号时(2)当前磁道号小于磁道序列中的最小的磁道号时(3)当前磁道号大于磁道序列中的最小的磁道号且小于最大磁道号时3 扫描算法(1)当前磁道号大于磁道序列中的最大的磁道号时(2)当前磁道号小于磁道序列中的最小的磁道号时(3)当前磁道号大于磁道序列中的最小的磁道号且小于最大磁道号(磁头向外)时(4)当前磁道号大于磁道序列中的最小的磁道号且小于最大磁道号(磁头向内)时4 循环扫描算法(1)当前磁道号大于磁道序列中的最大的磁道号时(2)当前磁道号小于磁道序列中的最小的磁道号时(3)当前磁道号大于磁道序列中的最小的磁道号且小于最大磁道号时

14、6、实验结果分析;本系统具有很强的健壮性,当输入错误数据类型时,系统提示用户输入的数据类型错误,让用户重新输入,保证系统的稳定性,不会因为用户的误操作而致使系统瘫痪;虽然是在dos状态下,但是本系统界面还是设计的比较漂亮的,具有比较好的交互性;对于软件中的重用代码,设计成一个函数,实现代码重用。本系统是在dos状态下进行编译执行的,没有图形化界面,可以设计出一个图形化界面,使用户操作更加简单,明了。用户使用时请注意:1、进入系统,用户根据提示依次输入磁道号,要结束时输入“0”,回车,输入磁盘号结束;2、系统输出你输入的磁道序列,用户核对输入数据3、系统显示系统算法菜单;4、用户选择相应算法,回

15、车;5、系统要求输入当前磁道号,用户输入磁道号,回车;6、系统输出磁头的扫描序列和平均寻道长度;7、用户继续选择系统菜单中的算法;8、当用户选择扫描算法时,需要输入磁道的寻道方向(1表示扫描磁道号大的方向,0表示扫描磁道号小的方向);六、 结论(应当准确、完整、明确精练;也可以在结论或讨论中提出建议、设想、尚待解决问题等。)通过此次课程设计,我对操作系统的基础知识了解得更透彻了,同时对磁盘调度的四种算法先来先服务算法(FCFS)、最短寻道时间优先算法(SSTF)、扫描算法(SCAN)、循环扫描算法(CSCAN)有了更深刻的理解和掌握,使我能够为磁盘调度选择适当的算法,提高CPU工作效率。设计过

16、程中遇到的困难在小组成员之间进行讨论,解决不了的问题,也在老师和同学的帮助下顺利解决并通过了验收,我深刻认识到算法的逻辑性对程序的重要影响,算法的准确度对程序运行结果的重要影响(例如,访问同样的磁道,在采用不同的算法,所用的平均寻道长度有明显差别),这对我以后在操作系统的学习中有极大帮。七、 参考文献计算机操作系统(第三版)汤小丹 梁红兵 哲凤平 汤子瀛 编著 西安电子科技大学出版社程序设计基础(第二版) 吴文虎 编著 清华大学出版社数据结构C语言描述 耿国华 主编 高等教育出版社八、 指导教师评语 签名: 年 月 日课程设计成绩附:1、课程设计的填写请按格式要求做;2、文字内容宋体、五号、1

17、.5倍行距;3、程序代码字体Times New Roman,五号、1.5倍行距; 附表:源程序代码#include#include#include#include#define maxsize 1000/*判断输入数据是否有效*/int decide(char str) /判断输入数据是否有效 int i=0;while(stri!=0) if(stri9)return 0;break;i+;return i;/*将字符串转换成数字*/int trans(char str,int a) /将字符串转换成数字int i;int sum=0;for(i=0;ia;i+)sum=sum+(int)(

18、stri-0)*pow(10,a-i-1);return sum;/*冒泡排序算法*/int *bubble(int cidao,int m) int i,j;int temp; for(i=0;im;i+) /使用冒泡法按从小到大顺序排列 for(j=i+1;jcidaoj) temp=cidaoi; cidaoi=cidaoj; cidaoj=temp; cout排序后的磁盘序列为:; for( i=0;im;i+) /输出排序结果 coutcidaoi ; coutendl; return cidao; /*先来先服务调度算法*/void FCFS(int cidao,int m) /磁

19、道号数组,个数为m int now;/当前磁道号 int sum=0; /总寻道长度 int j,i;int a;char str100; float ave; /平均寻道长度cout磁盘请求序列为:; for( i=0;im;i+) /按先来先服务的策略输出磁盘请求序列 coutcidaoi ; coutendl; coutstr; /对输入数据进行有效性判断 a=decide(str); if(a=0) cout输入数据的类型错误,请重新输入!endl; goto B; else now=trans(str,a); /输入当前磁道号 sum+=abs(cidao0-now);cout磁盘扫

20、描序列为:; for( i=0;im;i+) /输出磁盘扫描序列 coutcidaoi ; for(i=0,j=1;jm;i+,j+) /求平均寻道长度 sum+=abs(cidaoj-cidaoi); ave=(float)(sum)/(float)(m); coutendl; cout平均寻道长度:aveendl;/*最短寻道时间优先调度算法*/void SSTF(int cidao,int m) int k=1; int now,l,r; int i,j,sum=0; int a; char str100; float ave; cidao=bubble(cidao,m); /调用冒泡排

21、序算法排序 coutstr; /对输入数据进行有效性判断 a=decide(str); if(a=0) cout输入数据的类型错误,请重新输入!endl; goto C; else now=trans(str,a); /输入当前磁道号 if(cidaom-1=now) /若当前磁道号大于请求序列中最大者,则直接由外向内依次给予各请求服务 cout=0;i-) coutcidaoi=now) /若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务 cout磁盘扫描序列为:; for(i=0;im;i+) coutcidaoicidao0&nowcidaom-1) /若当前磁道号大于

22、请求序列中最小者且小于最大者 cout磁盘扫描序列为:; while(cidaok=0)&(rm) /当前磁道在请求序列范围内 if(now-cidaol)=(cidaor-now) /选择与当前磁道最近的请求给予服务 coutcidaol ; sum+=now-cidaol; now=cidaol; l=l-1; else coutcidaor ; sum+=cidaor-now; now=cidaor; r=r+1; if(l=-1) /磁头移动到序列的最小号,返回外侧扫描仍未扫描的磁道 for(j=r;jm;j+) coutcidaoj=0;j-) coutcidaoj ; sum+=c

23、idaom-1-cidao0; ave=(float)(sum)/(float)(m); coutendl; cout平均寻道长度: aveendl;/*扫描调度算法*/void SCAN(int cidao,int m) /先要给出当前磁道号和移动臂的移动方向 int k=1; int now,l,r,d; int i,j,sum=0; int a; char str100; float ave; cidao=bubble(cidao,m); /调用冒泡排序算法排序 coutstr; /对输入数据进行有效性判断 a=decide(str); if(a=0) cout输入数据的类型错误,请重新

24、输入!endl; goto D; else now=trans(str,a); /输入当前磁道号 if(cidaom-1=now) /若当前磁道号大于请求序列中最大者,则直接由外向内依次给予各请求服务,此情况同最短寻道优先 cout=0;i-) coutcidaoi=now) /若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务,此情况同最短寻道优先 cout磁盘扫描序列为:; for(i=0;im;i+) coutcidaoicidao0&nowcidaom-1) /若当前磁道号大于请求序列中最小者且小于最大者 while(cidaoknow) k+; l=k-1; r=k;

25、 coutd; if(d=0) /选择移动臂方向向内,则先向内扫描 cout=0;j-) coutcidaoj ; /输出向内扫描的序列 for(j=r;jm;j+) /磁头移动到最小号,则改变方向向外扫描未扫描的磁道 coutcidaoj ; /输出向外扫描的序列 sum=now-2*cidao0+cidaom-1; else /选择移动臂方向向外,则先向外扫描 cout磁盘扫描序列为:; for(j=r;jm;j+) coutcidaoj=0;j-) /磁头移动到最大号,则改变方向向内扫描未扫描的磁道 coutcidaoj ; sum=-now-cidao0+2*cidaom-1; ave

26、=(float)(sum)/(float)(m); coutendl; cout平均寻道长度: aveendl;/*循环扫描调度算法*/void CSCAN(int cidao,int m) int k=1; int now,l,r; int i,j,sum=0; int a; char str100; float ave; cidao=bubble(cidao,m); /调用冒泡排序算法排序 coutstr; /对输入数据进行有效性判断 a=decide(str); if(a=0) cout输入数据的类型错误,请重新输入!endl; goto E; else now=trans(str,a)

27、; /输入当前磁道号 if(cidaom-1=now) /若当前磁道号大于请求序列中最大者,则直接将移动臂移动到最小号磁道依次向外给予各请求服务 cout磁盘扫描序列为:; for(i=0;im;i+) coutcidaoi=now) /若当前磁道号小于请求序列中最小者,则直接由内向外依次给予各请求服务,此情况同最短寻道优先 cout磁盘扫描序列为:; for(i=0;im;i+) coutcidaoicidao0&nowcidaom-1) /若当前磁道号大于请求序列中最小者且小于最大者 cout磁盘扫描序列为:; while(cidaoknow) /单向反复地从内向外扫描 k+; l=k-1

28、; r=k; for(j=r;jm;j+) coutcidaoj ; /输出从当前磁道向外扫描的序列 for(j=0;jr;j+) /当扫描完最大号磁道,磁头直接移动到最小号磁道,再向外扫描未扫描的磁道 coutcidaoj ; sum=2*cidaom-1+cidaol-now-2*cidao0; ave=(float)(sum)/(float)(m); coutendl; cout平均寻道长度: aveendl;void main() int a; int c; /菜单项 int cidaomaxsize; int i=0,count; char str100; cout请输入磁道序列(0

29、结束):str; /对输入数据进行有效性判断 a=decide(str); if(a=0) cout输入数据的类型错误,请重新输入!str; /对输入数据进行有效性判断 a=decide(str); if(a=0) cout输入数据的类型错误,请重新输入!endl; else cidaoi=trans(str,a); i+; count=i-1; /要访问的磁道数 cout你输入的磁道序列为:; for(i=0;icount;i+) coutcidaoi ; /输出磁道序列 coutendl; while(1) /本系统最终解释权归黄淮计科0901所有 coutendl; cout*endl;

30、 cout* 系统菜单 *endl; cout*endl; cout* *endl; cout* 1. 先来先服务算法 *endl; cout* *endl; cout* 2. 最短寻道时间优先算法 *endl; cout* *endl; cout* 3. 扫描算法 *endl; cout* *endl; cout* 4. 循环扫描算法 *endl; cout* *endl; cout* 5. 退出 *endl; cout* *endl; cout*endl; cout*endl; G:coutstr; /对输入数据进行有效性判断 a=decide(str); if(a=0) cout输入数据的类型错误,请重新输入!5) cout数据输入错误!请重新输入endl; goto G; switch(c) case 1: /使用FCFS算法 FCFS(cidao,count); break; case 2: /使用SSTF算法 SSTF(cidao,count); break; case 3: /使用SCAN算法 SCAN(cidao,count); break; case 4: /使用CSCAN算法 CSCAN(cidao,count); break;

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!