进程的调度常用算法

简介: 进程的调度常用算法

先来先服务(FCFS)调度算法

系统将按照作业到达的先后次序来进行作业调度,或者说它是优先考虑在系统中等待时间最长的作业,而不管该作业所需执行时间的长短,从后备作业队列中优先选择几个最先进入该队列的作业,将他们调入内存,为他们分配资源和创建进程。然后把它放入就绪队列。当在进程调度中采用FCFS算法时,每次调度是从就绪的进程队列中选择一个最先进入该队列的进程,为之分配处理机,使之投入运行。该进程一直运行到完成或发生某事件而组赛后,进程调度程序才将处理机分配给其他进程。

在进程调度中采用先来先服务算法的时候,每次调度就从就绪队列中选一个最先进入该队列的进程,为之分配处理机,即谁第一排队谁就先被执行。

优点:

  1. 有利于长作业(进程)  
  2. 有利于CPU繁忙型的作业(进程)

缺点:

  1. 不利于短作业(进程)  
  2. 不利于I/O繁忙型的作业(进程)

短作业优先(SJF)的调度算法

SJF算法是以优先级作业的长短来计算优先级的,作业越短,其优先级越高,作业的长短是以作业所要求的运行时间来衡量的。SJF算法可以分别用于作业调度和进程调度。再把短作业优先调度算法用于作业调度时,它将从外存的作业后背队列张选择若干个运行时间最短的作业,优先将他们调入内存运行。

短进程优先调度算法是从就绪队列中选出一个估计运行时间最短的进程,再将处理机分配给它,直到执行完成,而其他进程一般不抢先正在执行的进程。

优点:

  1. 算法对长作业(进程)不利(长作业(进程)长期不被调度)    
  2. 未考虑进程的紧迫程度
  3. 由于是估计运行时间而定,而这个时间是由用户所提供的,所以该算法不一定能真正做到短作业优先调度

基于时间片的轮转调度(RR)算法

为了保证能及时响应用户的请求,所以我们采用了基于时间片的轮转调度算法,它的原理通俗来讲就是队列中每一个进程都获得了一定的执行时间,从几ms到几百ms,当一个执行时间结束,计时器会发出一个信号,此时正在执行的进程将被中断,同时此进程将被放在队列的末尾,然后执行这时候的队列的队首进程,因此队列中每一个进程都将获得一定时间执行。

RR算法(时间片轮转,假设时间片 q =1,q=2,q=4)来完成这些作业的调度情况

由于q=1,所以说明一次只能够运行一个

同理q=2,所以说明一次只能够运行两个

同理q=4,所以说明一次只能够运行四个

周转时间=完成时间-到达时间

带权周转时间=周转时间 / 服务时间

q=1

A

A

B

A

B

C

B

D

C

B

E

D

C

B

E

D

C

B

D

D

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

q=2

A

B

A

C

B

D

C

E

B

D

D

2

4

5

7

9

11

13

15

17

19

20

q=4

A

B

C

D

B

E

D

3

7

11

15

17

19

20

进程名

A

B

C

D

E

平均

q=1

到达时间

0

2

4

6

8

服务时间

3

6

4

5

2

完成时间

4

18

17

20

15

周转时间

4

16

13

14

8

10.8

带权周转时间

1.33

2.67

3.25

2.8

3.5

2.71

q=2

完成时间

5

17

13

20

15

周转时间

5

15

9

14

7

10.6

带权周转时间

1.67

2.5

2.25

2.8

3.5

2.54

q=4

完成时间

3

17

11

20

19

周转时间

3

15

7

14

11

10

带权周转时间

1

2.5

1.75

2.8

5.5

2.71

相关文章
|
8天前
|
算法 调度 云计算
操作系统中的调度算法:从理论到实践
在计算机科学领域,操作系统的调度算法是决定任务执行顺序的关键。本文首先概述了调度算法的基本概念和重要性,随后深入探讨了几种主要的调度算法,包括先来先服务、短作业优先、轮转与优先级调度等。通过引用最新的科研数据和实验证据,文章揭示了不同调度算法的性能表现和适用场景。此外,本文还讨论了现代操作系统中调度算法面临的挑战和未来的发展方向,强调了在多核处理器和云计算环境下调度策略的复杂性。最后,通过案例分析,展示了如何在实际系统中应用这些理论知识,以及在设计高效调度系统时需要考虑的因素。
|
10天前
|
机器学习/深度学习 算法 调度
操作系统中的进程调度策略
【6月更文挑战第26天】本文将深入探讨操作系统中的核心组件之一——进程调度。我们将从进程调度的基本概念入手,分析其重要性以及如何影响系统性能。文章将介绍几种常见的进程调度算法,并通过实例展示它们在实际操作系统中的应用。我们还将讨论现代操作系统中进程调度面临的挑战和未来可能的发展方向。
|
16天前
|
存储 负载均衡 算法
深入理解操作系统的进程调度
【6月更文挑战第20天】本文将探讨操作系统中的进程调度,包括其定义、重要性以及常见的调度算法。我们将通过具体的例子和代码片段来深入理解进程调度的工作原理和实现方式。最后,我们将讨论进程调度在现代操作系统中的应用和挑战。
|
18天前
|
算法 调度
基于变异混合蛙跳算法的车间调度最优化matlab仿真,可以任意调整工件数和机器数,输出甘特图
**摘要:** 实现变异混合蛙跳算法的MATLAB2022a版车间调度优化程序,支持动态调整工件和机器数,输出甘特图。核心算法结合SFLA与变异策略,解决Job-Shop Scheduling Problem,最小化总完成时间。SFLA模拟蛙群行为,分组进行局部搜索和全局信息交换。变异策略增强全局探索,避免局部最优。程序初始化随机解,按规则更新,经多次迭代和信息交换后终止。
|
18天前
|
调度
操作系统之进程调度机制
操作系统之进程调度机制
16 1
|
19天前
|
算法 调度
【调度算法】Boltzmann选择
【调度算法】Boltzmann选择
42 1
|
3天前
|
机器学习/深度学习 算法 数据挖掘
操作系统调度算法的演进与性能分析
随着计算机科学的发展,操作系统作为硬件与软件之间的桥梁,其调度算法对系统性能有着举足轻重的影响。本文将探讨操作系统中调度算法的演变,从早期的简单调度策略到现代复杂的多级反馈队列和实时调度机制,并结合最新研究和实验数据,深入分析不同调度算法对系统吞吐量、响应时间及资源利用率的影响。通过对调度算法性能的定量评估,本文旨在为系统设计者提供优化决策的理论依据,同时为未来调度算法的研究指明方向。
7 0
|
3天前
|
算法 调度
【重磅】“一招”解决智能算法中不满足“预期”的问题【以微电网优化调度为例】
摘要(Markdown格式): 在对微电网优化调度的模型复现中,发现智能算法(如改进粒子群优化)得出的结果有时不符合预期。例如,电网在低电价时段未满负荷购电,而高电价设备出力未相应降低,可能由于算法陷入局部最优或约束条件设置不当。为解决此问题,采用了梯级罚函数方法改进代码,以更好地满足预期的逻辑关系和优化目标。更新后的程序结果显示设备出力和电价成本的关系更符合预期,降低了运行成本。详细分析和改进后的程序结果图表可见相关链接。
|
9天前
|
算法 物联网 调度
操作系统调度算法的演进与性能评估
本文深入探讨了操作系统中进程调度算法的发展轨迹,从早期的先来先服务(FCFS)到现代的多级队列和反馈控制理论。通过引用实验数据、模拟结果和理论分析,文章揭示了不同调度策略如何影响系统性能,特别是在响应时间、吞吐量和公平性方面。同时,本文也讨论了在云计算和物联网等新兴领域,调度算法面临的挑战和未来的发展方向。
|
10天前
|
机器学习/深度学习 人工智能 算法
操作系统调度算法的演变与性能分析
操作系统作为计算机硬件和软件之间的桥梁,其调度算法的效率直接影响到系统的响应速度和资源利用率。本文将探讨从简单到复杂的各类调度算法,包括先来先服务、短作业优先、轮转法以及多级反馈队列等,通过数据分析揭示各算法的性能特点,并结合现代操作系统设计的需求,讨论未来调度算法的发展趋势。