操作系统-磁盘调度算法(二)

一、早期的磁盘调度算法

二、基于扫描的磁盘调度算法

三、举例说明


一、早期的磁盘调度算法

1.先来先服务(FCFS)

最简单的磁盘调度算法,它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进程的请求都能依次地得到处理,不会出现某一进程的请求长期得不到满足的情况。但此算法由于未对寻道进行优化,致使平均寻道时间可能较长。

2.最短寻道时间优先(SSTF)

该算法选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短,但这种算法不能保证平均寻道时间最短。

二、基于扫描的磁盘调度算法

1.扫描(SCAN)算法

SSTF算法的实质是基于优先级的调度算法,因此就可能导致优先级低的进程发生“饥饿”(Starvation)现象。

扫描(SCAN)算法不仅考虑到欲访问的磁道与当前磁道间的距离,更优先考虑的是磁头当前的移动方向。例如,当磁头正在自里向外移动时,SCAN算法所考虑的下一个访问对象应是其欲访问的磁道既在当前磁道之外,又是距离最近的。这样自里向外地访问,直至再无更外的磁道需要访问时,才将磁臂换向为自外向里移动。这时,同样也是每次选择这样的进程来调度:即要访问的磁道在当前位置内为距离最近者,这样,磁头又逐步地从外向里移动,直至再无更里面的磁道要访问,从而避免了出现“饥饿”现象。由于在这种算法中磁头移动的规律颇似电梯的运行,因而又称为电梯调度算法

2.循环扫描(CSCAN)算法

SCAN算法既能获得较好的寻道性能,又能防止“饥饿”现象,故被广泛用于大、中、小型机器和网络中的磁盘调度。但也存在着这样的问题:当磁头刚从里向外移动而越过了某一磁道时,恰好又有一进程请求访问此磁道,这时,该进程必须等待,待磁头继续从里向外,然后再从外向里扫描完处于外面的所有要访问的磁道后,才处理该进程的请求,致使该进程的请求被大大地推迟。

为了减少这种延迟,CSCAN算法规定磁头单向移动,例如,只是自里向外移动,当磁头移到最外的磁道并访问后,磁头立即返回到最里的欲访问磁道,亦即将最小磁道号紧接着最大磁道号构成循环,进行循环扫描。

三、举例说明

1.假设磁头当前位于第105道,正在向磁道序号增加的方向移动,现有一个磁道访问请求序列为:35,45,12,68,100,180,170,195,试用先来先服务调度算法、最短寻道时间优先算法、扫描调度算法、循环扫描调度算法分别给出响应序列并计算移道总次数。(需给出每次移动的磁道数)

先来先服务调度算法:【按磁道请求的顺序】

先来先服务调度算法
(从105道磁道开始)
被访问的下一磁道号移动距离(磁道数)
3570
4510
1233
6856
10032
18080
17010
19525
移动磁道总次数:316
平均寻道长度:39.5

最短寻道时间优先调度算法:【找距离最近的】

最短寻道时间优先调度算法
(从105道磁道开始)
被访问的下一磁道号移动距离(磁道数)
1005
6832
4523
3510
1223
170158
18010
19515
移动磁道总次数:276
平均寻道长度:34.5

扫描调度算法:【自里向外→自外向里】

扫描调度算法
(从105#磁道开始,向磁道增加的方向访问)
被访问的下一磁道号移动距离(磁道数)
17065
18010
19515
10095
6832
4523
3510
1223
移动磁道总次数:273
平均寻道长度:34.125

循环扫描调度算法:【自里向外(始终)】

循环扫描调度算法
(从105#磁道开始,向磁道增加的方向访问)
被访问的下一磁道号移动距离(磁道数)
17065
18010
19515
12183
3523
4510
6823
10032
移动磁道总次数:361
平均寻道长度:45.125
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值