进程调度时机切换与过程调度方式
进程调度的时机
进程调度
(低级调度),就是按照某种算法从就绪队列中选择一个进程为其分配处理机
进程在操作系统内核程序临界区
中不能
进行调度和切换,但进程在普通临界区中是可以进行调度、切换的
临界资源:一个时间段内只允许一个进程使用的资源。各进程需要互斥地
访问临界资源
临界区:访问临界资源的那段代码
内核程序临界区
一般是用来访问某种内核数据结构
的,比如进程的就绪队列
进程调度的方式
非剥夺调度方式
,又称非抢占方式
。即只允许进程主动放弃处理机。在运行过程即使有更紧迫的任务到达,当前进程依然会继续使用处理机,直到该进程终止或主动要求进入阻塞态
实现简单,系统开销小但是无法及时处理紧急任务,适合于早期的批处理系统
剥夺调度方式
,又称抢占方式
,当一个进程正在处理机上执行时,如果有一个更重要或者更紧迫的进程需要使用处理机,则立即暂停正在执行的进程,将处理机分配给更重要紧迫的那个进程
可以优先处理更紧迫的进程,也可以实现让各进程按照时间片轮流执行的功能(通过时钟中断)。适合于分时操作系统、实时操作系统
进程的切换和过程
“侠义的进程调度”与“进程切换”的区别:
侠义的进程调度
指的是从就绪队列中选中一个要运行的进程
。(这个进程可以是刚刚被暂停执行的进程,也可以是另一个进程
,后一种情况就需要进程切换
)
进程切换
是指一个进程让出处理机,另一个进程占用处理机的过程
广义上的进程调度
包含了选择一个进程和进程切换两个步骤
进程切换的过程主要完成了:
1、对原来运行进程各种数据的保存
2、如新的进程各个数据的恢复
(如:程序计数器、程序状态字、各种数据寄存器等处理机现场信息,这些信息一般保存在进程控制块)
注意:进程切换是有代价的
,因此如果过于频繁的
进行进程调度、切换
,必然会使整个系统的效率降低
,使系统大部分时间都花在了进程切换上,而真正用于进程执行的时间减少。
总结