【操作系统】磁盘调度算法

1、先来先服务(FCFS)

最简单的磁盘调度算法。根据进程请求访问磁盘的先后次序进行调度。(按顺序访问)

优点:公平、简单。

缺点:未对寻道进行优化,平均寻道时间可能较长。 

 适用:请求磁盘I/O的进程数目较少的场合。

例题:假设磁头当前位于第105道,正在向磁道序号增加的方向移动,现有一个磁道访问请求序列为:35,45,12,68,100,180,170,195,试用先来先服务调度算法给出响应序列并计算移道总次数。(需给出每次移动的磁道数)

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

注:移道总次数 = 所有移动距离(磁道数之和)

       平均寻道长度 = 移道总次数/寻道次数

 

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

要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短。(左右比,哪个最近优先访问)

算法不能保证平均寻道时间最短。

例题:假设磁头当前位于第105道,正在向磁道序号增加的方向移动,现有一个磁道访问请求序列为:35,45,12,68,100,180,170,195,试用最短距离优先调度算法给出响应序列并计算移道总次数。

(从105号磁道开始)
被访问的下一个磁道号移动距离(磁道数)
1005
6832
4523
3510
1223
170158
18010
19515
移道总次数:276
平均寻道长度为:34.5

 

3、扫描(SCAN)算法

扫描算法不仅考虑到欲访问的磁道与当前磁道间的距离,更优先考虑的是磁头当前的移动方向。

方法:首先可以将磁道号排序,按照当前磁头方向访问,到头后,再以当前位置开始向反方向访问。

例题:假设磁头当前位于第105道,正在向磁道序号增加的方向移动,现有一个磁道访问请求序列为:35,45,12,68,100,180,170,195,试用扫描调度算法给出响应序列并计算移道总次数。

(从105号磁道开始)
被访问的下一个磁道号移动距离(磁道数)
17065
18010
19515
10095
6832
4523
3510
1223
移道总次数:273
平均寻道长度为:34.1

思路:从小到大排序

12    、35    、45    、68    、100    、(105)    、170     、180    、195

                                                         (当前位置)增加的方向——>

                                     反方向<——(当前位置)

 

4、循环扫描(CSCAN)算法

CSCAN算法规定磁头单向移动,将最小磁道号紧接着最大磁道号构成循环,进行循环扫描。

例题:假设磁头当前位于第105道,正在向磁道序号增加的方向移动,现有一个磁道访问请求序列为:35,45,12,68,100,180,170,195,试用循环扫描调度算法给出响应序列并计算移道总次数。

(从105号磁道开始)
被访问的下一个磁道号移动距离(磁道数)
17065
18010
19515
12183
3523
4510
6823
10032
移道总次数:361
平均寻道长度为:45.1

思路:从小到大排序

   12    、35    、45    、68    、100    、(105)    、170     、180    、195

                                                           (当前位置)增加的方向——>

 (当前位置)增加的方向——>

到头后,以最小磁道号开始按增加的方向移动,可以把这个数列想象成一个圆圈(环),195的下一个数就是12(即:该数列的第一个数)

                                                                         

 

 

 

 

 

 

  • 5
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值