操作系统课程设计-磁盘调度模拟.doc_第1页
操作系统课程设计-磁盘调度模拟.doc_第2页
操作系统课程设计-磁盘调度模拟.doc_第3页
操作系统课程设计-磁盘调度模拟.doc_第4页
操作系统课程设计-磁盘调度模拟.doc_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

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

文档简介

目 录1.需求分析22. 数据结构的设计22.1 函数介绍23.程序概要设计内容23.1磁盘调度23.1.1先来先服务(fcfs)23.1.2最短时间优先算法33.1.3扫描(scan)调度算法33.1.4循环扫描(cscan)算法34.程序详细设计及流程图44.1系统流程图44.2先来先服务(fcfs)44.3最短寻道时间优先(sstf)54.4扫描算法(scan)54.5循环扫描(cscan)算法75.功能模块描述及使用说明85.1先来先服务调度(fcfs)85.2最短寻道时间优先调度(sstf)85.3扫描调度算法(scan)95.4循环扫描算法(cscan)106.心得体会及结束语117.参考文献11附源代码121. 需求分析操作系统的任务之一就是有效的使用硬件。对于磁盘驱动器,满足这一要求意味着要有较快的访问速度和较宽的磁盘带宽。访问时间包括两个主要部分:寻道时间,旋转延迟。磁盘带宽是所传递的总的字节数除以从服务请求开始到最后传递结束时的总时间。可以通过使用好的访问顺序来调度磁盘i/o请求,提高访问速度和宽度。本程序模拟四种磁盘调度算法:先来先服务调度(fcfs),最短寻道时间优先调度(sstf),扫描调度算法(scan),循环扫描算法(cscan)。并通过比较,了解各种算法的优缺点。2. 数据结构的设计2.1 函数介绍hand:当前磁道号;discline10:随机生成的磁道号;void setdi(int discl)生成随机磁道号算法;void copyl(int sour,int dist ,int x) 数组sour复制到数组dist,复制到x个数(四)详细设计;void delinq(int sour,int x,int y) 数组sour把x位置的数删除,x后的数组元素向前挪一位.void paixu()寻道长度由低到高排序void fcfs(int han,int discl)先来先服务算法(fcfs)void sstf(int han,int discl)最短寻道时间优先算法(sstf)int scan(int han,int discl,int x,int y) 扫描算法(scan)void cscan(int han,int discl)循环扫描算法(cscan)3.程序概要设计内容3.1磁盘调度在多道程序设计的计算机系统中,各个进程可能会不断提出不同的对磁盘进行读/写操作的请求。由于有时候这些进程的发送请求的速度比磁盘响应的还要快,因此我们有必要为每个磁盘设备建立一个等待队列。3.1.1先来先服务(fcfs)即先来的请求先被响应。fcfs策略看起来似乎是相当公平的,但是当请求的频率过高的时候fcfs策略的响应时间就会大大延长。fcfs策略为我们建立起一个随机访问机制的模型,但是假如用这个策略反复响应从里到外的请求,那么将会消耗大量的时间。为了尽量降低寻道时间,看来我们需要对等待着的请求进行适当的排序,而不是简单的使用fcfs策略。这个过程就叫做磁盘调度管理。有时候fcfs也被看作是最简单的磁盘调度算法。3.1.2最短时间优先算法要求访问的磁道,与当前磁头所在的磁道距离最近,以使每次的寻道时间最短。 3.1.3扫描(scan)调度算法该算法不仅考虑到欲访问的磁道与当前磁道间的距离,更优先考虑的是磁头当前的移动方向。例如,当磁头正在自里向外移动时,scan算法所考虑的下一个访问对象,应是其欲访问的磁道,既在当前磁道之外,又是距离最近的。这样自里向外的访问,直至再无更外的磁道需要访问时,才将磁道换向自外向里移动。这时,同样也是每次选择这样的进程来调度,也就是要访问的当前位置内距离最近者,这样,磁头又逐步地从外向里移动,直至再无更里面的磁道要访问,从而避免了出现“饥饿”现像。3.1.4循环扫描(cscan)算法当磁头刚从里向外移动而越过了某一磁道时,恰好又有一进程请求访问此磁道,这时,该里程就必须等待,为了减少这种延迟,cscan算法规定磁头单向移动,而本实验过程中我们所设计的是磁头从里向外移动,而从外向里移动时只须改方向而已,本实验未实现。但本实验已完全能演示循环扫描的全过程。4.程序详细设计及流程图4.1系统流程图: 4.2先来先服务(fcfs):这是一种简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。但此算法由于未对寻道进行优化,致使平均寻道时间可能较长。先来先服务算法(fcfs)流程图:4.3最短寻道时间优先(sstf):该算法选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短,但这种调度算法却不能保证平均寻道时间最短。最短寻道时间优先流程图:4.4扫描算法(scan):scan算法不仅考虑到欲访问的磁道与当前磁道的距离,更优先考虑的是磁头的当前移动方向。例如,当磁头正在自里向外移动时,scan算法所选择的下一个访问对象应是其欲访问的磁道既在当前磁道之外,又是距离最近的。这样自里向外地访问,直到再无更外的磁道需要访问才将磁臂换向,自外向里移动。这时,同样也是每次选择这样的进程来调度,即其要访问的磁道,在当前磁道之内,从而避免了饥饿现象的出现。由于这种算法中磁头移动的规律颇似电梯的运行,故又称为电梯调度算法。扫描算法(scan)流程图4.5循环扫描(cscan)算法:处理该进程的请求,致使该进程的请求被严重地推迟。为了减少这种延迟,cscan算法规定磁头单向移动。例如,只自里向外移动,当磁头移到最外的被访问磁道时,磁头立即返回到最里的欲访磁道,即将最小磁道号紧接着最大磁道号构成循环,进行扫描。循环扫描算法(cscan)流程图:5.功能模块描述及使用说明5.1先来先服务调度(fcfs)输入起始磁道(你可以输入100),点确定,进入第二个界面,再输入你要输入的最大磁道(你可以输入50),然后点确定。选择磁盘调度算法1 2 3 4中的任意一个,若选择1后确认,则随机输出10个小于50的磁道数(41 17 34 0 19 24 28 8 12 14),则先来先服务调度(fcfs)输出:(41 17 34 0 19 24 28 8 12 14),在选择1或者0,选着1则继续其它算法的磁盘调度,选着0则结束磁盘调度运行结果图:5.2最短寻道时间优先调度(sstf)输入起始磁道(你可以输入100),点确定,进入第二个界面,再输入你要输入的最大磁道(你可以输入50),然后点确定。选择磁盘调度算法1 2 3 4中的任意一个,若选择2后确认,则随机输出10个小于50的磁道数(5 45 31 27 11 41 45 42 27 36) ,则最短寻道时间优先调度(sstf):(45 45 42 41 36 31 27 27 11) 。在选择1或者0,选着1则继续其它算法的磁盘调度,选着0则结束磁盘调度.运行结果图:5.3扫描调度算法(scan)输入起始磁道(你可以输入100),点确定,进入第二个界面,再输入你要输入的最大磁道(你可以输入50),然后点确定。选择磁盘调度算法1 2 3 4中的任意一个,若选择3后确认,则随机输出10个小于50的磁道数:(41 4 2 3 42 32 21 16 18 45),则扫描调度算法(scan):(45 42 41 32 21 18 16 4 3 2) 。在选择1或者0,选着1则继续其它算法的磁盘调度,选着0则结束磁盘调度。运行结果图:5.4循环扫描算法(cscan)输入起始磁道(你可以输入100),点确定,进入第二个界面,再输入你要输入的最大磁道(你可以输入50),然后点确定。选择磁盘调度算法1 2 3 4中的任意一个,若选择4后确认,则随机输出10个小于50的磁道数:(47 26 21 38 19 12 17 49 35 44),则循环扫描算法(cscan):(12 17 19 21 26 35 38 44 47 49)。运行结果图:6.心得体会及结束语至此,计算机操作系统课程设计算法已经完成。此次设计基本完成了所规定的功能,但由于这次设计的时间比较仓促,其中不免会有些纰漏,比如在程序的实现上还不够严谨,出错处理不够完善等多方面问题,这些都有进一步改善。 由于平时上课不是很认真许多概念没有理解清楚,导致在做设计时有点无从下手的感觉,只好边实验边看书直到弄懂概念后才开始做设计导致时间有点紧张,最终在同学和老师的指导下我完成了设计,此设计基本能够实现规定的要求但是还是不够完善,很多东西做的不够好,程序不够完善和严谨。此次课程设计中我学到了很多东西,无论在理论上还是实践中,都得到不少的提高,这对于我以后的工作和学习都有一种巨大的帮助。7.参考文献(1) 汤小丹 梁红兵 哲凤屏 汤子瀛 编著. 计算机操作系统(第三版).西安电子科技大学出版社. 2007.(2) 谭浩强 编著.c程序设计(第三版).清华大学出版社.2005附源代码#include stdio.h#include stdlib.hvoid copyl(int sour,int dist ,int x); /数组sour复制到数组dist,复制到x个数void setdi(int discl); /随机生成磁道数 void print(int pri,int x); /打印输出数组privoid delinq(int sour,int x,int y); /数组sour把x位置的数删除,并把y前面的数向前移动,y后的数保持不变(即会出现2个y) void fcfs(int han,int discl); /先来先服务算法(fcfs)void sstf(int han,int discl); /最短寻道时间优先算法(sstf)int scan(int han,int discl,int x,int y); /扫描算法(scan)void cscan(int han,int discl); /循环扫描算法(cscan)/void n_step_scan(int han1,int discl); /n步扫描算法(nstepscan)void paixu(); /寻道长度由低到高排序void pri();int nall=0;int best52; /用作寻道长度由低到高排序时存放的数组 int limit=0; /输入寻找的范围磁道数iint jage;float aver=0;int main() int i; int discline10; /声明准备要生成的随机磁道号的数组 int hand; /磁道数 int con=1; int n; while(con=1) jage=0; printf(n 请输入初始的磁道数(0n65536) printf(超出范围!); elseprintf( *n);printf( * 磁盘调度算法 *n); printf( *n); printf(* 1.先来先服务算法(fcfs) *n); printf( * 2.最短寻道时间优先算法(sstf) *n); printf( * 3.扫描算法(scan) *n); printf( * 4.循环扫描算法(cscan) *n); printf( *n); scanf(%d,&n); if(n=0) exit(0); printf(n); switch(n) case 1: setdi(discline); /随机生成磁道数 fcfs(hand,discline); /先来先服务算法(fcfs) break; case 2: setdi(discline); /随机生成磁道数 sstf(hand,discline); /最短寻道时间优先算法(sstf) break; case 3: setdi(discline); /随机生成磁道数 scan(hand,discline,0,9); /扫描算法(scan) break; case 4: setdi(discline); /随机生成磁道数 cscan(hand,discline); /循环扫描算法(cscan) break; case 5: setdi(discline); /随机生成磁道数 setdi(discline); /随机生成磁道数 fcfs(hand,discline); /先来先服务算法(fcfs) sstf(hand,discline); /最短寻道时间优先算法(sstf) scan(hand,discline,0,9); /扫描算法(scan) cscan(hand,discline); /循环扫描算法(cscan) paixu(); /寻道长度由低到高排序 printf(nn+ 寻道长度由低到高排序:); for(i=0;i5;i+) printf(%4d ,besti0); break; printf(nn+ 是否继续(按0结束,按1继续)?); scanf(%5d,&con); /数组sour复制到数组dist,复制到x个数void copyl(int sour,int dist ,int x) int i; for(i=0;i=x;i+) disti=souri; /打印输出数组privoid print(int pri,int x) int i; for(i=0;i=x;i+) printf(%5d,prii); /随机生成磁道数void setdi(int discl) int i; for(i=0;i=9;i+) discli=rand()%limit;/随机生成10个磁道号 printf(+ 需要寻找的磁道号:); print(discl,9); /输出随机生成的磁道号 printf(n);/数组sour把x位置的数删除,并把y前面的数向前移动,y后的数保持不变(即会出现2个y) void delinq(int sour,int x,int y) int i; for(i=x;iy;i+) souri=souri+1; x+; /先来先服务算法(fcfs)void fcfs(int han,int discl) int rline10; /将随机生成的磁道数数组discl复制给数组rline int i,k,all,temp; /temp是计算移动的磁道距离的临时变量 all=0; /统计全部的磁道数变量 k=9; /限定10个的磁道数 copyl(discl,rline,9); /复制磁道号到临时数组rline printf(n+ 按照fcfs算法磁道的访问顺序为:); all=han-rline0; for(i=0;i=9;i+) temp=rline0-rline1;/求出移动磁道数,前一个磁道数减去后一个磁道数得出临时的移动距离 if(temp0) temp=(-temp);/移动磁道数为负数时,算出相反数作为移动磁道数 printf(%5d,rline0); all=temp+all;/求全部磁道数的总和 delinq(rline,0,k);/每个磁道数向前移动一位 k-; bestjage1=all;/best1存放移动磁道数 bestjage0=1; /best0存放算法的序号为:1 jage+;/排序的序号加1 aver=(float) all)/10;/求平均寻道次数 printf(n+ 移动磁道数: ,all); printf(n+ 平均寻道长度:*%0.2f* ,aver);/最短寻道时间优先算法(sstf)void sstf(int han,int discl) int i,j,k,h,all; int temp; /temp是计算移动的磁道距离的临时变量 int rline10; /将随机生成的磁道数数组discl复制给数组rline int min; all=0; /统计全部的磁道数变量 k=9; /限定10个的磁道数 copyl(discl,rline,9); /复制磁道号到临时数组rline printf(n+ 按照sstf算法磁道的访问顺序为:); for(i=0;i=9;i+) min=64000; for(j=0;jhan) /如果第一个随机生成的磁道号大于当前的磁道号,执行下一句 temp=rlinej-han; /求出临时的移动距离 else temp=han-rlinej; /求出临时的移动距离 if(tempmin) /如果每求出一次的移动距离小于min,执行下一句 min=temp; /temp临时值赋予min h=j; /把最近当前磁道号的数组下标赋予h all=all+min; /统计一共移动的距离 printf(%5d,rlineh); han=rlineh; delinq(rline,h,k); /每个磁道数向前移动一位 k-; bestjage1=all;/best1存放移动磁道数 bestjage0=2;/best0存放算法的序号为:2 jage+;/排序序号加1 aver=(float)all)/10;/求平均寻道次数 printf(n+ 移动磁道数: ,all); printf(n+ 平均寻道长度:*%0.2f* ,aver);/扫描算法(scan)int scan(int han,int discl,int x,int y) int j,n,k,h,m,all; int t=0; int temp; int min; int rline10; /将随机生成的磁道数数组discl复制给数组rline int order; order=1; k=y; m=2; /控制while语句的执行,即是一定要使当前磁道向内向外都要扫描到 all=0; /统计全部的磁道数变量 copyl(discl,rline,9); /复制磁道号到临时数组rline printf(n+ 按照scan算法磁道的访问顺序为:); min=64000; for(j=x;jhan) /如果第一个随机生成的磁道号大于当前的磁道号,执行下一句 temp=rlinej-han; /求出临时的移动距离 else temp=han-rlinej; /求出临时的移动距离 if(temp=han) /判断磁道的移动方向,即是由里向外还是由外向里 order=0; t=1; han=rlineh; delinq(rline,h,k); /每个磁道数向前移动一位 k-; while(m0) if(order=1) /order是判断磁盘扫描的方向标签,order是1的话,磁道向内移动 for(j=x;j=y;j+) h=-1; min=64000; for(n=x;n=k;n+) /判断离当前磁道最近的磁道号 if(rlinen=han) temp=han-rlinen; if(tempmin) min=temp; /temp临时值赋予min h=n; /把最近当前磁道号的数组下标赋予h if(h!=-1) all=all+min; /叠加移动距离 printf(%5d,rlineh); han=rlineh; /最近的磁道号作为当前磁道 delinq(rline,h,k); k-; order=0; /当完成向内的移动,order赋予0,执行else语句,使磁道向外移动 m-; /向内完成一次,m减一次,保证while循环执行两次 else /order是0的话,磁道向外移动 for(j=x;j=y;j+) h=-1; min=64000; for(n=x;n=han) temp=rlinen-han; if(temp5) bestjage1=all;/best1存放移动磁道数 bestjage0=3;/best0存放算法的序号为:3 jage+;/排序序号加1 aver=(float)all)/10;/求平均寻道次数 printf(n+ 移动磁道数: ,all); printf(n+ 平均寻道长度:*%0.2f* ,aver); if(t=1) print

温馨提示

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

评论

0/150

提交评论