OS实验指导五——磁盘调度模拟(新2014-12-15)

上传人:豆浆 文档编号:23881784 上传时间:2017-12-03 格式:DOC 页数:9 大小:73KB
返回 下载 相关 举报
OS实验指导五——磁盘调度模拟(新2014-12-15)_第1页
第1页 / 共9页
OS实验指导五——磁盘调度模拟(新2014-12-15)_第2页
第2页 / 共9页
OS实验指导五——磁盘调度模拟(新2014-12-15)_第3页
第3页 / 共9页
OS实验指导五——磁盘调度模拟(新2014-12-15)_第4页
第4页 / 共9页
OS实验指导五——磁盘调度模拟(新2014-12-15)_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《OS实验指导五——磁盘调度模拟(新2014-12-15)》由会员分享,可在线阅读,更多相关《OS实验指导五——磁盘调度模拟(新2014-12-15)(9页珍藏版)》请在金锄头文库上搜索。

1、OS 实验指导五 2013 师范班+2014 信管第 1 页 共 9 页操作系统实验指导五开课实验室: 实验楼 A207,A209 实验类型 验证实验项目(五)磁盘调度模拟实验实验学时 4一、实验目的用不同算法实现对磁盘调度的模拟实现,并比较各算法性能。二、设备与环境1. 硬件设备:PC 机一台2. 软件环境:安装 Windows 操作系统或者 Linux 操作系统,并安装相关的程序开发环境,如 C C+Java 等编程语言环境。三、实验要求设计并实现一个分别利用下列磁盘调度算法进行磁盘调度的模拟程序。 (1)扫描算法 (2)循环扫描算法设计要求:1. 磁头初始磁道号,磁头初始运动方向,序列长

2、度,磁道号序列等数据可键盘输入。 2. 最好能实现磁道号序列中磁道号的动态增加。 3. 磁道访问序列以链表的形式存储。 4. 给出各磁盘调度算法的调度顺序和平均寻道长度。四、实验设计参考1. 算法说明(1)扫描算法(SCAN)扫描算法不仅考虑到欲访问的磁道与当前磁道的距离,更优先考虑的是磁头的当前移动方向。例如,当磁头正在自里向外移动时,扫描算法所选择的下一个访问对象应是其欲访问的磁道既在当前磁道之外,又是距离最近的。这样自里向外地访问,直到再无更外的磁道需要访问才将磁臂换向,自外向里移动。这时,同样也是每次选择这样的进程来调度,即其要访问的磁道,在当前磁道之内,从而避免了饥饿现象的出现。由于

3、这种算法中磁头移动的规律颇似电梯的运行,故又称为电梯调度算法。此算法基本上克服了最短寻道时间优先算法的服务集中于中间磁道和响应时间变化比较大的缺点,而具有最短寻道时间优先算法的优点即吞吐量较大,平均响应时间较小,但由于是摆动式的扫描方法,两侧磁道被访问的频率仍低于中间磁道。2、循环扫描算法(CSCAN)循环扫描算法是对扫描算法的改进。如果对磁道的访问请求是均匀分布的,当磁头到达磁盘的一端,并反向运动时落在磁头之后的访问请求相对较少。这是由于这些磁道刚被处理,而磁盘另一端的请求密度相当高,且这些访问请求等待的时间较长,为了解决这种情况,循环扫描算法规定磁头单向移动。例如,只自里向外移动,当磁头移

4、到最外的被访问磁道时,磁头立即返回到最里的欲访磁道,即将最小磁道号紧接着最大磁道号构成循环,进行扫描。OS 实验指导五 2013 级师范+2014 信管专业第 2 页2. 主要功能模块流程图3.源程序参考如下: #include #include #include #include #include#include using namespace std;class LinList;struct LinNodeint no;LinNode *next;class LinList开始手动输入磁道选择调度算法SCAN 算法 CSCAN 算法显示运行结果结束向内寻道 向外寻道OS 实验指导五 201

5、3 级师范+2014 信管专业第 3 页private :LinNode *head;public :int size;LinList() /构造函数,用于构造头结点和声明长度head=new LinNode;head-next=NULL;size=0;void Insert(int no)/插入函数LinNode *newnode=new LinNode;newnode-no=no;newnode-next=NULL;Index(size-1)-next=newnode;size+;LinNode *Index(int i)/定位函数if(isize-1)coutnext;LinNode *

6、p=head-next;int k=0;while(p!=NULL&knext;k+;return p;void SCAN1(int start_place)/电梯调度算法(向外寻道)coutSCAN调度算法(向外寻道)如下: ; OS 实验指导五 2013 级师范+2014 信管专业第 4 页float sum=0;float ave;int *a=sort();for( i=0 ; i;if(m=i)sum+=abs(start_place-ai);elsesum+= abs(am-ai) ;for(int n=i-1;n=0;n-)if(n=i-1)sum+=abs(an-asize-1

7、);if(n!=i-1)sum+=abs(an-an+1);if(n=0)cout;ave= sum/size ;cout平均寻道长度为:SCAN调度算法(向内寻道)如下: ; float sum=0;float ave;int *a=sort();for(int i=0;i=0;n-)OS 实验指导五 2013 级师范+2014 信管专业第 5 页if(n=i-1)sum+=abs(an-ai);if(n!=i-1)sum+=abs(an-an+1);if(n=0)cout;elsecout;for(int m=i;m;if(m=i)sum+=abs(start_place-a0);else

8、sum+=abs(am-am-1);cout平均寻道长度为:CSCAN调度算法如下: ;float sum=0;float ave;int *a=sort();for(int i=0;i;if(m=i)sum+=abs(start_place-ai);elsesum+=abs(am-am-1);OS 实验指导五 2013 级师范+2014 信管专业第 6 页for(int n=0;n;ave= sum/size ;cout平均寻道长度为:nono;int *sort()/排序int count=0;int *a=new int size;a0=Index(0)-no;count+;for(in

9、t i=1;inoj;k-)ak=ak-1;aj=Index(i)-no;count+ ;break;if(Index(i)-no=aj)OS 实验指导五 2013 级师范+2014 信管专业第 7 页if(j=count-1)acount=Index(i)-no;count+;break;elsecontinue;return a;void main()cout请输入需要调度的序列(以0结束):;while(cini&i)linlist.Insert(i);cout请输入开始的磁道号:;cinstart_place;cout链表的长度为:单链表显示:;linlist.show();int f

10、lag=1;while(flag)cout请输入数字:;int k;cink;switch(k)case 1:main();break;OS 实验指导五 2013 级师范+2014 信管专业第 8 页case 2:linlist.CSCAN(start_place);break;case 3:cout;int j;cinj;switch(j)case 5:linlist.SCAN1(start_place);break;case 6:linlist.SCAN2(start_place);break;break;case 4:flag=0;break;cout输入任意字符结束:endl;getche();五、思考提高:1. 试选用其它算法如最短寻道优先算法实现磁盘调度模拟。2. 分析以上算法会否出现“磁臂粘着”现象。OS 实验指导五 2013 级师范+2014 信管专业第 9 页

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号