# 调度,第 2 部分:调度过程:算法
> 原文:<https://github.com/angrave/SystemProgramming/wiki/Scheduling%2C-Part-2%3A-Scheduling-Processes%3A-Algorithms>
## 什么是众所周知的调度算法?
对于所有的例子,
过程 1:运行时 1000ms
过程 2:运行时 2000ms
过程 3:运行时 3000ms
过程 4:运行时 4000ms
过程 5:运行时 5000ms
## 最短的工作优先(SJF)
![](https://img.kancloud.cn/0d/49/0d49b79ff99e485b5daed82421ca73c9_604x340.jpg)
* P1 到达:0ms
* P2 到达:0ms
* P3 到达:0ms
* P4 到达:0ms
* P5 到货:0ms
这些进程都在开始时到达,并且调度程序以最短的总 CPU 时间调度作业。明显的问题是这个调度程序需要知道该程序在运行程序之前将持续运行多长时间。
技术说明:实际的 SJF 实现不会使用进程的总执行时间,而是使用突发时间(包括将来计算执行之前的总 CPU 时间将不再准备好运行)。可以通过使用基于先前突发时间的指数衰减加权滚动平均来估计预期突发时间,但是对于该展示,我们将简化该讨论以使用该过程的总运行时间作为突发时间的代理。
**优势**
* 较短的工作往往先运行
**缺点**
* 需要算法是无所不知的
## 抢先最短的工作优先(PSJF)
先抢先最短的作业首先是最短的作业,但是如果新作业的运行时间短于过程的剩余运行时间,则运行该作业。 (如果它与我们的算法相同,我们的算法可以选择)。调度程序使用进程的总运行时间,如果你想剩下最短 _ 剩余 _ 时间,那就是 PSJF 的变体,称为 Shortest Remaining Time First。
![](https://img.kancloud.cn/8e/aa/8eaa82e20d259820cb53b2dd149bcd37_605x340.jpg)
* P2 在 0ms
* P1 在 1000ms
* P5 在 3000ms
* P4 在 4000ms
* P3 在 5000ms
这是我们的算法所做的。它运行 P2 因为它是唯一运行的东西。然后 P1 进入 1000ms,P2 运行 2000ms,所以我们的调度程序先发制人地停止 P2,让 P1 一直运行(这完全取决于算法因为时间相等)。然后,P5 进入 - 由于没有进程正在运行,调度程序将运行进程 5.P4 进入,并且由于运行时间等于 P5,调度程序停止 P5 并运行 P4。最后 P3 进入,抢占 P4,并运行完成。然后 P4 运行,然后 P5 运行。
**Advantages**
* 确保较短的工作首先运行
**Disadvantages**
* 需要再次了解运行时
**注意:**此算法因历史原因比较总运行时间 _ 而非 _ 剩余运行时间。如果您想考虑剩余时间,您将使用抢先最短剩余时间优先(PSRTF)。
## 先到先得(FCFS)
![](https://img.kancloud.cn/ce/95/ce95e81a82fe1fa17cbefc1fd256b311_605x340.jpg)
* P2 在 0ms
* P1 在 1000ms
* P5 在 3000ms
* P4 在 4000ms
* P3 在 5000ms
进程按到达顺序安排。 FCFS 的一个优点是调度算法很简单:就绪队列只是一个 FIFO(先进先出)队列。 FCFS 遭遇康宏效应。
在这里 P2 到达,然后 P1 到达,然后是 P5,然后是 P4,然后是 P3。你可以看到 P5 的护航效果。
**Advantages**
* 简单的实施
**Disadvantages**
* 长时间运行的进程可以阻止所有其他进程
## Round Robin(RR)
进程按其到达就绪队列的顺序进行安排。但是,经过一小段时间后,将强制从运行状态中删除正在运行的进程并将其放回就绪队列。这可确保长时间运行的进程不会使所有其他进程无法运行。进程在返回就绪队列之前可以执行的最长时间称为时间量。在大时间量子点(时间量子长于所有过程的运行时间)的限制下,循环将等同于 FCFS。
![](https://img.kancloud.cn/ef/76/ef7672e0378d84c54966c02685b8c046_605x340.jpg)
* P1 到达:0ms
* P2 到达:0ms
* P3 到达:0ms
* P4 到达:0ms
* P5 到货:0ms
量子= 1000ms
这里所有进程都在同一时间到达。 P1 运行 1 个量程并完成。 P2 为一个量子;然后,P3 停止了。在为量子运行所有其他进程之后,我们循环回到 P2,直到完成所有进程。
**Advantages**
* 确保一些公平的概念
**Disadvantages**
* 大量进程=大量切换
## 优先
进程按优先级顺序排列。例如,导航过程执行可能比记录过程更重要。
- UIUC CS241 系统编程中文讲义
- 0. 简介
- #Informal 词汇表
- #Piazza:何时以及如何寻求帮助
- 编程技巧,第 1 部分
- 系统编程短篇小说和歌曲
- 1.学习 C
- C 编程,第 1 部分:简介
- C 编程,第 2 部分:文本输入和输出
- C 编程,第 3 部分:常见问题
- C 编程,第 4 部分:字符串和结构
- C 编程,第 5 部分:调试
- C 编程,复习题
- 2.进程
- 进程,第 1 部分:简介
- 分叉,第 1 部分:简介
- 分叉,第 2 部分:Fork,Exec,等等
- 进程控制,第 1 部分:使用信号等待宏
- 进程复习题
- 3.内存和分配器
- 内存,第 1 部分:堆内存简介
- 内存,第 2 部分:实现内存分配器
- 内存,第 3 部分:粉碎堆栈示例
- 内存复习题
- 4.介绍 Pthreads
- Pthreads,第 1 部分:简介
- Pthreads,第 2 部分:实践中的用法
- Pthreads,第 3 部分:并行问题(奖金)
- Pthread 复习题
- 5.同步
- 同步,第 1 部分:互斥锁
- 同步,第 2 部分:计算信号量
- 同步,第 3 部分:使用互斥锁和信号量
- 同步,第 4 部分:临界区问题
- 同步,第 5 部分:条件变量
- 同步,第 6 部分:实现障碍
- 同步,第 7 部分:读者编写器问题
- 同步,第 8 部分:环形缓冲区示例
- 同步复习题
- 6.死锁
- 死锁,第 1 部分:资源分配图
- 死锁,第 2 部分:死锁条件
- 死锁,第 3 部分:餐饮哲学家
- 死锁复习题
- 7.进程间通信&amp;调度
- 虚拟内存,第 1 部分:虚拟内存简介
- 管道,第 1 部分:管道介绍
- 管道,第 2 部分:管道编程秘密
- 文件,第 1 部分:使用文件
- 调度,第 1 部分:调度过程
- 调度,第 2 部分:调度过程:算法
- IPC 复习题
- 8.网络
- POSIX,第 1 部分:错误处理
- 网络,第 1 部分:简介
- 网络,第 2 部分:使用 getaddrinfo
- 网络,第 3 部分:构建一个简单的 TCP 客户端
- 网络,第 4 部分:构建一个简单的 TCP 服务器
- 网络,第 5 部分:关闭端口,重用端口和其他技巧
- 网络,第 6 部分:创建 UDP 服务器
- 网络,第 7 部分:非阻塞 I O,select()和 epoll
- RPC,第 1 部分:远程过程调用简介
- 网络复习题
- 9.文件系统
- 文件系统,第 1 部分:简介
- 文件系统,第 2 部分:文件是 inode(其他一切只是数据...)
- 文件系统,第 3 部分:权限
- 文件系统,第 4 部分:使用目录
- 文件系统,第 5 部分:虚拟文件系统
- 文件系统,第 6 部分:内存映射文件和共享内存
- 文件系统,第 7 部分:可扩展且可靠的文件系统
- 文件系统,第 8 部分:从 Android 设备中删除预装的恶意软件
- 文件系统,第 9 部分:磁盘块示例
- 文件系统复习题
- 10.信号
- 过程控制,第 1 部分:使用信号等待宏
- 信号,第 2 部分:待处理的信号和信号掩码
- 信号,第 3 部分:提高信号
- 信号,第 4 部分:信号
- 信号复习题
- 考试练习题
- 考试主题
- C 编程:复习题
- 多线程编程:复习题
- 同步概念:复习题
- 记忆:复习题
- 管道:复习题
- 文件系统:复习题
- 网络:复习题
- 信号:复习题
- 系统编程笑话