文章目录
前言
本文记录的是进程的就绪态、执行态、睡眠态/挂起态、暂停态、僵尸态、死亡态
一、图示
总结
就绪态:
当程序被用户执行/其父进程调用fork成功常见一个进程则进入就绪状态
就绪状态并不代表正在运行,必须被CPU执行才称为运行态
就绪态实质是实在一个队列中按照优先级排队等待
运行态:
进程从就绪状态被 sched( )被称(调度器)选中进入CPU 并逐条处理他的指令
在运行态下如果时间片被耗光则该进程会回到就绪态的队列末尾中重新排队等待
如果被更高优先级的进程抢占时间,则进程回到就绪态的队列头部进行等待
在运行态中如果由于某个资源暂时不可获得将会进入挂起/睡眠状态
睡眠/挂起:
由于某个资源暂时不可获得
用户使用seelp函数
TASK_INTERRUPIBLE 或者 TASK_UNINTERRUPIBLE
TASK_INTERRUPIBLE 浅睡眠, 进程在该状态下可以别信号唤醒(比如等待某个文件的资源, 当资源可获得的时候将会产生一个信号把你唤醒)
TASK_UNINTERRUPIBLE 与某些硬件相关, 深度睡眠, 在睡眠过程中不会响应信号
暂停态:
当进程收到 SIGSTOP 或者 SIGTSTP 之一则会从运行态变为暂停态
在该状态下不参与系统的任何调度
一直要等到 SIGCONT 才会重新参与系统进程调度
僵尸态:
当进程退出(主函数遇到renturn / 调用exit … 等) 情况下进程退出,进入到僵尸状态
僵尸状态下的尸体中存放退出的各种状态以及信息,比如是否真否正常退出,退出值 / 异常退出, 退出原
因 / 信号杀死 , 信号的值是多少等信息
等待父进程来查看子进程的尸体,获取其中的数据
当父进程成功获取到子进程的退出信息后,则会把该僵尸设置为退出状态(真正走向死亡)
死亡态
应该由父进程调用wait( ) / waitpid( )来查看孩子的“死亡信息” , 从而把该进程的状态设置为死亡状态
如果父进程事前挂掉了,那么该进程由祖父进程(INIT)来接受并处理他的尸体