操作系统 —— 调度算法

       (一)如何学习各种调度算法:

1.算法思想

2.该调度算法适用于作业调度还是进程调度

3.抢占式还是非抢占式

4.优点和缺点

5.是否会导致饥饿(某进程/作业长期得不到服务)

(例题)

 假设一个系统中有5个进程,它们达到时间和服务时间如图所示,忽略I/O及其他开销时间,若分别按先来先服务(FCFS)、非抢占式及抢占式短进程优先(SPF)、高响应比优先(HRRN)、时间片轮转(RR,时间片大小为1)、多反馈队列调度算法(FB,第i及队列的时间片=2i-1)进行CPU调度,请给出各进程的完成时间、周转时间、等待时间、带权周转时间、平均周转时间和平均带权周转时间。

进程

到达时间

服务时间

A

0

3

B

C

4  

4

D

5

E

8

2

FCFS:先到先得; 

各进程的等待时间为: A:0  B:1  C:6  D:8  E:11 

SPF

各进程的等待时间为: A:0    B:1   C:8   D:10    E:2

非抢占:完成一个比对一个,谁小谁来。抢占:一有情况马上对比,谁小谁来。

周转时间-服务时间=等待时间 

各进程的等待时间为: A:0   B:7   C:0   D:9   E:0

HRRN 

响应比

  • 响应比Rp = (等待时间+要求服务时间)/ 要求服务时间 = 1 +(等待时间 / 要求服务时间)

 RR

RR:系统将所有就绪进程按到达时间的先后次序排成一个队列,进程调度程序总是选择就绪队列中第一个进程执行,即先来先服务的原则,但仅能运行一个时间片。在使用完一个时间片后,即使进程并未完成其运行,它也必须释放出(被剥夺)处理机给下一个就绪的进程,而被剥夺的进程返回到就绪队列的末尾重新排队,等候再次运行。

FB

原理:多个就绪队列,第一队列优先级最高;赋予各个队列中进程执行时间片的大小不一样,优先级越高的队列中,多个进程的运行时间片越小;新进程进入内存后,按FCFS原则排队等待调度。

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
(1)、假定系统有五个进程,每一个进程用一个进程控制块PCB来代进程控制块的格式 (2)、每次运行你所设计的处理器调度程序之前,为每个进程任意确定它的“要求运行时间”。 把五个进程按顺序排成循环队列,用指针指出队列连接情况。另用一标志单元记录轮到运行的进程。 (3)、处理器调度总是选择标志单元指示的进程运行。由于本实验是模拟处理器调度的功能,所以,对被选中的进程并不实际启动运行 (4)、进程运行一次后,应把该进程进程控制块中的指针值送到标志单元,以指示下一个轮到运行的进程。同时,应判断该进程的要求运行时间与已运行时间,若该进程要求运行时间≠已运行时间,则示它尚未执行结束,应待到下一轮时再运行。若该进程的要求运行时间=已运行时间,则示它已经执行结束,应把它的状态修改为“结束”(E)且退出队列。此时,应把该进程进程控制块中的指针值送到前面一个进程的指针位置。 (5)、若“就绪”状态的进程队列不为空,则重复上面(4)和(5)的步骤,直到所有进程都成为“结束”状态。 (6)、在所设计的称序中应有显示或打印语句,能显示或打印每次被选中进程进程名以及运行一次后进称对列的变化。 (7)、为五个进程任意确定一组“要求运行时间”,启动所设计的处理器调度程序,显示或打印逐次被选中进程进程名以及进程控制块的动态变化过程。
SRTF(Shortest Remaining Time First)算法是一种短作业优先的进程调度算法,其规则如下: 1. 当一个进程进入就绪队列时,系统会计算出该进程还需要执行的时间。 2. 在就绪队列中选择剩余时间最短的进程先执行。 3. 如果另一个进程进入就绪队列,其剩余时间比当前正在执行的进程还要短,那么系统会立即切换到该进程执行。 4. 如果有多个进程剩余时间相同,则按照先进先出的原则进行调度。 下面是一个例题: 假设有 4 个进程,它们的到达时间、执行时间和剩余时间如下所示: | 进程 | 到达时间 | 执行时间 | 剩余时间 | |------|----------|----------|----------| | P1 | 0 | 5 | 2 | | P2 | 1 | 3 | 1 | | P3 | 2 | 4 | 4 | | P4 | 3 | 2 | 2 | 按照 SRTF 算法进行调度,其执行过程如下: 1. 时间片 0,P1 进入就绪队列。 2. 时间片 1,P2 进入就绪队列,P1 剩余时间为 4,P2 剩余时间为 2,执行 P2。 3. 时间片 2,P1 剩余时间为 3,P4 进入就绪队列,P4 剩余时间为 2,执行 P4。 4. 时间片 3,P1 剩余时间为 2,P4 剩余时间为 1,执行 P1。 5. 时间片 4,P3 进入就绪队列,P1 剩余时间为 1,执行 P1。 6. 时间片 5,P3 剩余时间为 3,执行 P3。 7. 时间片 6,P3 剩余时间为 2,执行 P3。 8. 时间片 7,P3 剩余时间为 1,执行 P3。 9. 时间片 8,所有进程执行完毕。 根据上述执行过程,可以发现 SRTF 算法可以有效地缩短进程的等待时间和响应时间,提高系统的吞吐量和响应速度。但是,由于它需要不断地计算进程剩余时间,因此会增加系统的开销。此外,在实际应用中,需要根据实际情况选择合适的进程调度算法

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尘 关

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值