磁盘的调度

预习报告

一、实验内容

   模拟电梯调度算法,实现对磁盘的调度。 

二、实验目的

磁盘是一种高速、大量旋转型、可直接存取的存储设备。它作为计算机系统的辅助存储器,负担着繁重的输入输出任务,在多道程序设计系统中,往往同时会有若干个要求访问磁盘的输入输出请示等待处理。系统可采用一种策略,尽可能按最佳次序执行要求访问磁盘的诸输入输出请求,这就叫磁盘调度,使用的算法称磁盘调度算法。磁盘调度能降低为若干个输入输出请求服务所须的总时间,从而提高系统效率。本实验要求学生模拟设计一个磁盘调度程序,观察磁盘调度程序的动态运行过程。

三、实验原理

模拟电梯调度算法,对磁盘调度。

磁盘是要供多个进程共享的存储设备,但一个磁盘每个时刻只能为一个进程服务。

当有进程在访问某个磁盘时,其他想访问该磁盘的进程必须等待,直到磁盘一次工作结束。

当有多个进程提出输入输出请求处于等待状态,可用电梯调度算法从若干个等待访问者中选择一个进程,让它访问磁盘。当存取臂仅需移到一个方向最远的所请求的柱面后,如果没有访问请求了,存取臂就改变方向。

    假设磁盘有200个磁道,用C语言随机函数随机生成一个磁道请求序列(不少于15个)放入模拟的磁盘请求队列中,假定当前磁头在100号磁道上,并向磁道号增加的方向上移动。请给出按电梯调度算法进行磁盘调度时满足请求的次序,并计算出它们的平均寻道长度。

实验报告

一、实验内容

   模拟电梯调度算法,实现对磁盘的调度。 

二、实验目的

磁盘是一种高速、大量旋转型、可直接存取的存储设备。它作为计算机系统的辅助存储器,负担着繁重的输入输出任务,在多道程序设计系统中,往往同时会有若干个要求访问磁盘的输入输出请示等待处理。系统可采用一种策略,尽可能按最佳次序执行要求访问磁盘的诸输入输出请求,这就叫磁盘调度,使用的算法称磁盘调度算法。磁盘调度能降低为若干个输入输出请求服务所须的总时间,从而提高系统效率。本实验要求学生模拟设计一个磁盘调度程序,观察磁盘调度程序的动态运行过程。

三、实验原理

模拟电梯调度算法,对磁盘调度。

磁盘是要供多个进程共享的存储设备,但一个磁盘每个时刻只能为一个进程服务。

当有进程在访问某个磁盘时,其他想访问该磁盘的进程必须等待,直到磁盘一次工作结束。

当有多个进程提出输入输出请求处于等待状态,可用电梯调度算法从若干个等待访问者中选择一个进程,让它访问磁盘。当存取臂仅需移到一个方向最远的所请求的柱面后,如果没有访问请求了,存取臂就改变方向。

    假设磁盘有200个磁道,用随机函数随机生成一个磁道请求序列(不少于15个)放入模拟的磁盘请求队列中,假定当前磁头在100号磁道上,并向磁道号增加的方向上移动。请给出按电梯调度算法进行磁盘调度时满足请求的次序,并计算出它们的平均寻道长度。

四、算法流程图

五、源程序及注释

#include<stdio.h>

#include<stdlib.h>

#include <time.h>

int main(){

int m,n,l;

int cg;

int cl[20];

srand((unsigned)time(NULL));

for(m=0;m<20;m++){

for(n=0;n<20;n++)

cl[n]=rand()%200;

printf("(%d)\n初始序列:",m+1);

for(n=0;n<20;n++)

printf("%d  ",cl[n]);

for(n=0;n<20;n++){

for(l=n+1;l<20;l++){

if(cl[n]<cl[l]){

cg=cl[n];

cl[n]=cl[l];

cl[l]=cg;

}

}

}

for(n=0;cl[n]>=100;n++);

cg=n;

printf("\n执行序列:");

for(n=cg-1;n>=0;n--)

printf("%d  ",cl[n]);

for(n=cg;n<20;n++)

printf("%d  ",cl[n]);

printf("\n平均寻道长度:%lf\n\n",1.0*(2*cl[0]-cl[19]+-100)/20);

}

return 0;

}

六、打印的程序运行时初值和运行结果

  • 实验小结

本次实验是使用电梯调度算法来实现。在程序的设计过程中,我使用了循环来实现,执行时间主要用在了寻找距离最短并且同方向的磁道上。所以可以再寻找更好的排序算法来降低时间复杂度。SCAN算法是在磁头前进方向上的最短查找时间优先算法,排除了磁头在盘面局部位置上的往复移动。这种算法是从移动臂当前位置开始沿着臂的移动方向去选择离当前移动臂最近的那个柱访问者,如果沿臂移动的方向无请求访问时,就改变臂的移动方向再选择。起初对于这个实验的原理还不够了解,所以在编写程序时花费了一些时间,但是在完成实验后,对这个算法的理解更加通透了。

  • 20
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
磁盘调度算法是操作系统中的重要组成部分,它负责决定磁盘上的数据访问顺序,以提高磁盘的访问效率。常见的磁盘调度算法包括先来先服务(FCFS)、最短寻道时间优先(SSTF)、扫描算法(SCAN)等。在JavaFX中,我们可以通过图形化界面来实现磁盘调度算法的可视化演示。 首先,我们可以利用JavaFX提供的Canvas类来创建一个模拟磁盘的可视化界面,用于展示磁盘上的数据分布以及磁头的移动情况。然后,通过JavaFX的事件响应机制,可以实现用户输入磁盘访问请求的功能,比如输入某个磁道的请求,然后演示磁头移动的过程。 接着,我们可以编写相应的Java代码来实现各种磁盘调度算法的逻辑。比如实现FCFS算法时,可以按照请求的先后顺序来访问磁道;而实现SSTF算法时,则需要动态地选择距离磁头最近的磁道进行访问;而SCAN算法则需要模拟磁头来回扫描磁道的移动过程。 最后,将磁盘模拟界面和各种调度算法的逻辑结合起来,通过JavaFX的界面刷新机制,实时展示磁头的移动轨迹和磁盘的访问顺序。这样用户就可以直观地了解不同调度算法对磁盘访问效率的影响,从而更好地理解操作系统中的磁盘调度原理。这样的可视化演示不仅可以帮助学生更好地学习磁盘调度算法,也为开发人员提供了一个直观的工具来优化磁盘访问性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值