4.状态间的六种转换情况

  • 1.运行——>就绪
    • 1,主要是进程占用CPU的时间过长,而系统分配给该进程占用CPU的时间是有限的
    • 2,在采用抢先式优先级调度算法的系统中,当有更高优先级的进程要运行时,该进程就被迫让出CPU,该进程便由执行状态转变为就绪状态
  • 2.就绪——>运行
    • 运行的进程的时间片用完,调度就转到就绪队列中选择合适的进程分配CPU
  • 3.运行——>阻塞
    • 正在执行的进程因发生某等待事件而无法执行,则进程由执行状态变为阻塞状态,如发生了I/O请求
  • 4.阻塞——>就绪
    • 进程所等待的事件已经发生,就进入就绪队列

以下两种状态是不可能发生的

  • 5.阻塞——>运行
    • 即使给阻塞进程分配CPU,也无法执行,操作系统在进行调度时不会从阻塞队列进行挑选,而是从就绪队列中选取
  • 6.就绪——>阻塞
    • 就绪态根本就没有执行,谈不上进入阻塞态

另外一个版本

  • (1)新状态->就绪态
    • 当等待队列允许接纳新进程时,内核便把新进程移入等待队列。
  • (2)就绪态->运行态
    • 调度类选中等待队列中的某个进程,该进程进入运行态。
  • (3)运行态->睡眠态
    • 正在运行的进程因需要等待某事件(如IO等待、信号等待等)的出现而无法执行,进入睡眠态。
  • (4)睡眠态->就绪态
    • 进程所等待的事件发生了,进程就从睡眠态排入等待队列,等待下次被选中执行。
  • (5)运行态->就绪态
    • 正在执行的进程因时间片用完而被暂停执行;或者在抢占式调度方式中,高优先级进程强制抢占了正在执行的低优先级进程。
  • (6)运行态->终止态
    • 一个进程已完成或发生某种特殊事件,进程将变为终止状态。对于命令来说,一般都会返回退出状态码。

以上引用:http://www.cnblogs.com/f-ck-need-u/p/7058920.html这位大佬

posted on 2018-09-01 14:37  圆缘  阅读(668)  评论(0编辑  收藏  举报

返顶部