操作系统---常见进程调度算法

常见进程调度算法

轮转调度算法(RR)、优先级调度算法、多队列调度算法、多级反馈队列调度算法、保证调度算法、公平分享调度算法。

1 轮转调度算法(RR)

(1)原理:在轮转法中,系统将所有的就绪进程按先来先服务(FIFC)策略排成一个就绪队列。系统可设置每隔一定时间便产生一次中断,去激活进程调度程序进行调度,把CPU分配给队首进程,并令其执行一个时间片。当它运行完毕后,又把处理机分配给就绪队列中新的队首进程,也让它执行一个时间片。这样,就保证就绪队列中的所有进程在确定的时间段内,都能获得一个时间片的处理机时间。

(2) 进程切换时机

在RR调度算法中,应在何时进行进程的切换,可分两种情况:

第一种:若一个时间片尚未用完,正在运行的进程便一完成,就立即激活调度程序,将它从就绪队列中删除,再调度就绪队列中队首的进程运行,并启动一个新的时间片。

第二种:在一个时间片用完后,计时器中断处理程序被激活。如果进程尚未运行完毕,调度程序就将它送往就绪队列的末尾。

2 优先级调度算法

在轮转调度算法中,做了一个隐含的假设,即系统中所有进程的紧迫性是相同。但事实并非如此,为了满足实际情况的需要,在进程中引入了优先级,从而形成了下面之中算法---优先级调度算法。

(1)优先级调度算法的类型

优先级进程调度算法,是把处理机分配给就绪队列中优先级的最高的进程。这时,又可进一步把算法分成如下两种:

第一种:非抢占式优先级调度算法。该算法规定,一旦把处理机分配给就绪队列中优先级最高的进程,该进程便一直执行下去直至完成。或者该进程发生某种事件而放弃处理机时,系统才将处理机重新分配给另一优先级最高的进程。

第二种:抢占式优先级调度算法。处理机分配给就绪队列中优先级最高的进程,使之执行。但在其执行之间,只要出现优先级更高的进程,调度算法就将处理机分配给新的优先级最高的进程。

(2)优先级类型

优先级调度算法的关键在于:应如何确定进程的优先级,以及确定是使用静态优先级还是动态优先级。

静态优先级:在创建进程时确定的,在进程的整个运行期间保持不变。

动态优先级:在创建进程之初,先赋予其一个优先级,然后在其值随进程的推进或者等待时间的增加而改变,以便获得更好的调度性能。

3、多队列调度算法

前述的各种调度算法,尤其在应用于进程调度时,由于系统中仅设置一个进程的就绪队列,即低级调度算法是固定的,单一的,无法满足系统中不同用户对进程调度策略的不同要求,在多处理机系统中,这种单一调度策略实现机制的缺点更显突出,由此,多级队列调度算法能够在一定程度上弥补这一点。

该算法将系统中的进程就绪队列从一个拆分为若干个,将不同类型或性质的进程固定分配在不同的就绪队列,不同的就绪队列采取不同的调度算法,一个就绪队列中的进程可设置不同的优先级,不同的就绪队列本身也可以设置不同的优先级。

多队列调度算法由于设置多个就绪队列,因此对每个就绪队列就可以实施不同的调度算法,因此,系统针对不同用户进程的需求,很容易提供多种调度策略。

【前面介绍的各种进程调度算法都有一定的局限性。如果没有指明进程长度,则短进程优先和基于进程长度的抢占式调度算法都将无法使用。而下面所说的多级反馈队列调度算法则不必事先知道各种进程所需的执行时间,还可以较好的满足各种类型进程的需要,因而它是目前公认的一种较好的进程调度算法】

4、多级反馈队列调度算法

多级反馈队列调度算法的调度机制可如下描述:

(1) 设置多个就绪队列。在系统中设置多个就绪队列,并为每个队列赋予不同的优先级。第一个队列优先级最高,第二个次之,其余队列的优先级逐个降低。该算法为不同队列中的进程所赋予的时间片的长短也不同,在优先级越高的队列中,其时间片就越小。

(2)每个队列都采用FCFS算法。当新进程进入内存后,首先将它放入第一队列的末尾,按FCFS原则等待调度。当轮到该进程执行时,如它能够在时间片内完成,便可撤离系统,否则,即它在一个时间片内未完成,调度程序将其转入第二队列的末尾等待调度,如果它在第二队列中运行一个时间片后仍未完成,再次将它放入第三队列。。。,依次类推。当进程最后降到第n队列后,在第n队列中采取按RR方式运行。

(3) 按队列优先级调度。调度程序首先调度最高优先级队列中的诸进程运行。仅当第一队列空闲时才调度第二队列中的进程运行;换言之,仅当1-[i-1]所有队列均为空时,才会调度第i队列中的进行运行。如果处理机正在第i队列中为某一进程服务时又有新的进程进入任一优先级较高的队列,此时立即把正在运行的进程放回到第i队列的末尾,而把处理机分配给新到的高优先级进程。

调度算法性能

如果规定第一个队列的时间片略大于多数人机交互所需之处理时间时,能较好的满足各种类型的用户的需求。

(1)终端型用户

(2)短批处理作业用户

(3)长批处理作业用户

基于公平原则的调度算法

5、保证调度算法:非配给【每个进程】相同的处理机时间。

6、公平分享调度算法:非配给【每个用户】相同的处理机时间。

时间: 2024-08-27 21:50:57

操作系统---常见进程调度算法的相关文章

常见进程调度算法

常见进程调度算法 一.先来先服务和短作业(进程)优先调度算法 1.先来先服务调度算法 先来先服务(FCFS)调度算法是一种最简单的调度算法,该算法既可用于作业调度,也可用于进程调度.当在作业调度中采用该算法时,每次调度都是从后备作业队列中选择一个或多个最先进入该队列的作业,将它们调入内存,为它们分配资源.创建进程,然后放入就绪队列.在进程调度中采用FCFS算法时,则每次调度是从就绪队列中选择一个最先进入该队列的进程,为之分配处理机,使之投入运行.该进程一直运行到完成或发生某事件而阻塞后才放弃处理

浅析几个常见进程调度算法

今天来谈谈操作系统的几个常见的进程调度算法.那么第一步首先要了解什么是进程调度算法?简单来说就是根据系统的资源分配策略所规定的资源分配算法.举个例子来说明.假设任务一在执行完成后选择哪个任务来进行使得某一因素最小,这个因素可能是进程执行的总时间或是磁盘寻道时间等等.因此对于不同的系统目标有着不同的要求,要选择的调度算法也就不尽相同.接下来,就聊聊几个常见的进程调度算法.  First>>  先来先服务调度算法  FCFS 先来先服务(FCFS)调度算法是一种最简单的调度算法,该算法既可用于作业

操作系统常见的调度算法

调度算法是指:根据系统的资源分配策略所规定的资源分配算法,如任务A在执行完后,选择哪个任务来执行,使得某个因素(如进程总执行时间,或者磁盘寻道时间等)最小.对于不同的系统目标,通常采用不同的调度算法.几个常用的操作系统进程调度算法 一.先来先服务和短作业(进程)优先调度算法 1 先来先服务(队列) 先来先服务(FCFS)调度算法是一种最简单的调度算法,该算法既可用于作业调度,也可用于进程调度.当在作业调度中采用该算法时,每次调度都是从后备作业队列中选择一个或多个最先进入该队列的作业,将它们调入内

进程调度算法总结

所谓进程,简单来说是计算机中的各种任务,那么计算机如何分配系统资源以供这些任务使用呢?此篇博客目的就是为大家整理一下几种常见进程调度算法. 进度调度就是按照一定的策略,动态地把处理机分配给处于就绪队列的进程,使之执行. 常见的进程调度算法: 1.先来先服务和短作业(进程)优先调度算法 2.高优先权优先调度算法 3.基于时间片的轮转调度算法 下面细说: 1.先来先服务和短作业优先调度算法 1.1.先来先服务调度算法 这种调度算法由字面意思理解很直观,所谓先来先服务,就是谁先来先服务谁.结合进程,先

Linux 常见的进程调度算法

1.在介绍进程调度之前,先对进程的状态的概念应该有所了解,下面是关于进程状态的一些基本概念:进程的状态分为三种,分别为: 1).运行态:该状态表明进程在实际占用CPU 2).就绪态: 该状态下进程可以运行,但因为其他进程正在运行而暂时停止 3).阻塞态: 该状态下进程不能运行,除非某种外部事件的发送 运行态→等待态 往往是由于等待外设,等待主存等资源分配或等待人工干预而引起的. 等待态→就绪态 则是等待的条件已满足,只需分配到处理器后就能运行. 运行态→就绪态 不是由于自身原因,而是由外界原因使

操作系统中常见的调度算法

一.先来先服务调度算法 先来先服务的调度算法(FCFS)是一种最简单的调度算法,该算法既可以用于作业调度,也可以用于进程调度.当在作业调度中采用该算法时,每次都是从后备作业队列选择一个或多个最先进入该队列的作业,将他们调入内存,为他们分配内存,为他们分配资源,创建进程,然后放入就绪队列中.在进程中采用FCFS算法时,则每次调度室从就绪队列中选择一个最先进入该队列的进程,位置分配处理机,使之投入运行.该进程一直运行到完成或发生某事件而阻塞后才放弃处理机. FCFS调度算法有利于cpu繁忙型的作业,

操作系统中常用的进程调度算法

操作系统中对进程的调度算法大体上可以分为三类: 1.先来先服务算法 2.优先级法 3.时间片轮法 接下来简要介绍一下这三类算法. 一.先来先服务算法 (FCFS:    First Come First Service) 原理: 这是最简单的一种调度算法,用到了队列的思想.每次调度都从进程就绪队列中选择队首的进程(也就是最先进入队列的进程)进行调度. 直到进程的执行被阻塞,或进程结束,再调用下一个进程,依然是从队列中选择队首的进程的. 这里要注意,上文我说的队列中的进程实际上是进程的PCB,因为

常见进程的调度算法

调度算法是指:根据系统的资源分配策略所规定的资源分配算法,如任务A在执行完后,选择哪个任务来执行,使得某个因素(如进程总执行时间,或者磁盘寻道时间等)最小.对于不同的系统目标,通常采用不同的调度算法. 几个常用的操作系统进程调度算法. 1 先来先服务(队列) 先来先服务(FCFS)调度算法是一种最简单的调度算法,该算法既可用于作业调度,也可用于进程调度.当在作业调度中采用该算法时,每次调度都是从后备作业队列中选择一个或多个最先进入该队列的作业,将它们调入内存,为它们分配资源.创建进程,然后放入就

《操作系统_时间片轮转RR进程调度算法》

转自:https://blog.csdn.net/houchaoqun_xmu/article/details/55540250 时间片轮转RR进程调度算法 一.概念介绍和案例解析时间片轮转法 - 基本原理:  在早期的时间片轮转法中,系统将所有的就绪进程按先来先服务的原则排成一个队列,每次调度时,把CPU分配给队首进程,并令其执行一个时间片.时间片的大小从几ms到几百ms.当执行的时间片用完时,由一个计时器发出时钟中断请求,调度程序便据此信号来停止该进程的执行,并将它送往就绪队列的末尾:然后,