




免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
课程设计报告【最短寻道时间优先算法】名称:操作系统课程设计题目:最短寻道时间优先算法院系:班级:学号:学生姓名:指导教师: 日期: 2007年6 月19 日一、课程设计目的通过课程设计,加深学生对教材中的重要算法的理解,同时通过用C语言编程实现这些算法,让学生更好地掌握操作系统的原理及实现方法,提高学生综合运用各专业课知识的能力。二、课程设计内容以下设计课题任选一个即可:编程序实现下述磁盘调度算法,并求出各种算法的平均寻道长度:1、先来先服务算法(FCFS)2、最短寻道时间优先算法(SSTF)3、扫描算法(SCAN)4、循环扫描算法(CSCAN)三、课程设计原理最短寻道时间优先算法(SSTF)。最短寻道时间优先算法总是让离当前磁道最近的请求访问者启动磁盘驱动器,即是让查找时间最短的那个作业先执行,而不是考虑请求访问者到来的先后次序。四、课程设计程序清单最短寻道时间优先算法/版权所有 未经同意严禁COPY#include #include #define MAXSIZE 100int devbufMAXSIZE; /保存输入的访问柱面号int devbuflen; /保存访问序列的长度int count; /记录磁头移动的总距离void initbuf(void) int i; for(i = 0; i MAXSIZE; i +) devbuf = -1; devbuflen = 0; count = 0;/读文件/成功返回1,失败返回0int readfile(void) FILE* pfile; char filename256; int tmp,i,j; printf(请输入文件名:n); scanf(%s,filename); pfile = fopen(filename,rt); if(pfile = NULL) printf(文件不存在n); return 0; j = 0; i = fscanf(pfile,%d,&tmp); while(i != EOF) & (i != 0) devbufj = tmp; j +; i = fscanf(pfile,%d,&tmp); fclose(pfile); devbuflen = j; return 1;/显示缓冲区中内容void displaybuf(void) int i; printf(输入的序列:n); for(i = 0; i devbuflen; i +) printf(%d ,devbuf); printf(n);/对输入的序列排序/这里使用选择排序,柱面号最小的排在最前void sortdev(void) int i,j,k,l; for(i = 0; i devbuflen-1; i +) /循环debbuflen-1,每次选出最小的排在前面,最后一个不用排 k = i; for(j = i+1; j devbuflen; j +) /选出最小的一个 if(devbufj devbuf) & (i = i; j -) devbufj+1 = devbufj; devbuf = num; /插入 devbuflen +; return i;/从当前位置开始,选择离当前位置最近的柱面输出/如果有两个柱面的距离相同,选择柱面号小的那个输出/输入参数curloc为当前位置void selectshort(int curloc) /最短优先 int j,k; printf(最短寻道时间优先磁道访问算法输出:n); while(devbuflen 0) printf(%d ,devbufcurloc); k = curloc; if(devbuflen 1) if(curloc = 0) /当前位置在第一个 count += (devbufcurloc+1 - devbufcurloc); else if(curloc = devbuflen -1) /当前位置在最后一个 count += (devbufcurloc - devbufcurloc-1); curloc -; else /选择最近一个 if(devbufcurloc+1 - devbufcurloc) (devbufcurloc - devbufcurloc-1) count += (devbufcurloc+1 - devbufcurloc); else count += (devbufcurloc - devbufcurloc-1); curloc -; for(j = k+1; j devbuflen; j +) /删除访问过的柱面 devbufj-1 = devbufj; devbuflen -; void main() int i,average,cishu;scanf(“%d”,&cishu) initbuf(); readfile(); displaybuf(); sortdev(); printf(排序后:n); displaybuf(); i = insertdev(100); selectshort(i); getch();average=cout/cishu;printf(“%fn”,average)五、课程设计程序清单执行结果1:请输入文件名2:请输入磁盘读写请求队列:23 376 205132 19 61 190 398 29 4 18 40 3:请输入寻道次数:cishu=124:磁头移动次序:132 190 205 61 40 29 23 19 18 4 376 3985:磁头移动总道数:cout=7006:平均移动道数:average=700/12=58.3六、课程设计总结采用这种调度算法,克服了先来先服务调度算法中磁臂移动过大的问题。虽然减少了磁臂的移动距离,但会经常改
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 第4课 家乡大头贴说课稿-2025-2026学年小学信息技术大连理工版四年级上册-大连理工版
- 2024年五年级数学上册 四 多边形的面积第5课时 探索活动:三角形的面积(1)配套说课稿 北师大版
- 广安中考试题及答案数学
- 工务安规考试题及答案
- 可持续发展驱动下的鞋服企业品牌塑造
- 数据驱动型决策模式下的财务会计转型路径
- 法学转本考试题及答案
- 2025艺人演出代理合同
- 经典的家具购买合同6篇
- 视频制作基础试题及答案
- 阴道镜项目质量管理方案
- 边坡工程第3章 边坡工程地质勘察
- 索思医疗卓越产品系列穿戴式动态心电监测产品
- 全国医药行业特有职业技能竞赛中药调剂员赛项备赛试题库(含答案)
- 中建基础设施公司“主要领导讲质量”
- 房屋交易诚意金合同范本模板
- 《毛泽东思想的形成与发展》参考课件3
- GB/T 4706.95-2024家用和类似用途电器的安全第95部分:商用电动抽油烟机的特殊要求
- JTG 3362-2018公路钢筋混凝土及预应力混凝土桥涵设计规范
- 脑梗死知识讲解模板
- 女性中医保健智慧树知到期末考试答案章节答案2024年暨南大学
评论
0/150
提交评论