2.1.3 进程控制
目录
2.1.3.1 基本概念
在书中,进程控制的定义是这样的:进程控制是进程管理中最基本的功能。它用于创建一个新进程,终止一个已完成的进程,或终止一个因出现某事件而使其无法运行下去的进程,还可负责进程运行中的状态转换。其实简单来说,进程控制就是为了实现进程状态之间的转换。
那么进程控制是怎么实现的呢?进程控制一般来说是通过OS内核中的原语来实现的。原语(Primitive)是由若干条指令组成的,用于完成一定功能的一个过程,它是一个不可分割的基本单位,因此,在执行过程中不允许被中断。原子操作在管态下执行,常驻内存。
为什么要使用原子操作(一气呵成)呢?如果系统对进程的控制如不使用原语,就会造成其状态的不确定性,从而达不到进程控制的目的。比如说将执行态变为阻塞态需要两步,首先将state的值改变之后再将此PCB放在阻塞队列,如果非原子操作,在改变state值之后发生中断,那么在执行队列就出现了阻塞态的PCB,这是不正确的。
如何保证操作的原子性呢?这里我们需要引出两个特权指令:开中断指令和关中断指令。顾名思义,开中断就是将中断打开,关中断就是将中断关闭。我们将要执行的操作放在开中断与关中断指令的中间,CPU执行了关中断指令之后,就不再例行检查中断信号,直到执行开中断指令之后才会恢复检查。这样,关中断、开中断 之间的这些指令序列就是不可被中断的,这就实现了“原子性”。