目录
- 前言
- 一、运行态
- 二、终止态
- 三、阻塞态
- 四、挂起态
- 五、Linux中的其他进程状态
- 1. R(running):运行态
- 2. S(sleeping):睡眠状态
- 3. D(disk sleeping):阻塞状态
- 4. Z和X状态:死亡与僵尸
- 5. T(Stopping):暂停状态
- 6.t(tracing stopping):追踪暂停状态
- 总结
前言
在操作系统中,由于进程的数量是非常多的,而系统的资源又非常少,所以不可能每一个进程在每时每刻都会处于上处理机运行的状态,所以在系统中应该要为进程维护好相关的状态:运行态,终止态,阻塞态,挂起态,还有Linux中特有的其他进程状态:R(Running),S(Sleeping),D(disk
sleeping),T(stopping),t(trace stopping)
一、运行态
说到进程的运行状态,很多同学可能第一时间想到的是此时进程应该在处理机上运行,这个时候的进程所处的状态就称为运行态
其实并不是的,我们可以思考:在系统中一般只有一个处理机,而进程的数量又非常庞大,如果说,上处理机处理的运行的进程才称为运行态,那么进程在处理机上的运行切换又是非常快的,所以就会导致进程的状态不断发生改变,从而维护进程属性的PCB结构体中的进程相关状态信息的值会频繁发生变化,显然这是不合理的,也没有必要。因此,如果正确定义进程的运行态呢??进程在载入内存的时候,通常操作系统会为该程序创建一个PCB结构体来维护该进程中的相关信息,那么当这一切的准备工作全部准备就绪的时候,这个PCB结构体就会被放入CPU相应的运行队列中,那么此时我们就称该进程已经处于运行态
总结来说,就是一个进程中的PCB结构体加入运行队列中随时准备上处理机运行的状态就称为运行态,此时进程在内存中。
如图是CPU中的运行队列的大致图,上述所有在运行队列中的进程都处于运行状态
二、终止态
终止态是指一个进程在运行结束之后,不需要再上处理机运行的状态,对应的PCB加入到终止队列中,此时我们称这样的进程处于终止状态
思考:为什么进程在结束运行不再需要上处理机运行时不直接被操作系统回收,而需要维护一个终止态呢?
操作系统在回收相关进程的资源的时候不是一蹴而就的,而是需要花费一定的时间和开销,因此,在回收之前需要维护一个终止队列,对应PCB处于终止队列上的进程就是处于终止态此时进程在内存中。
三、阻塞态
这个可以类比进程的运行态,但是与进程的运行态不同的是,运行态等待的是CPU资源,而阻塞态是由于等待一些非CPU资源而无法运行的状态,同样也会维护相应的等待队列,这个等待队列因等待的资源不同而有所差异,比如常见等待的资源:磁盘,显卡,网卡,打印机,因此这些资源都会维护对应的等待队列,比如:磁盘等待队列,网卡等待队列,显卡等待队列等,此时进程在内存中。
此过程会发生的事情:
- 当前进程的PCB会从runqueue中移除
- 当前进程的PCB会被加入到对应等待资源的等待队列中
- 对应进程的PCB中的进程的状态会被改变
四、挂起态
挂起态也属于一种等待状态,和阻塞态稍微优点类似,不过,挂起态的本质原因是操作系统中的内存资源不够,进程的数量太多,导致系统的压力非常大,因此此时操作系统为了释放压力,必须将一些暂时不需要运行的进程中的相关的代码和数据先置换到磁盘上,一般情况下,磁盘都会预先留出一部分空间:swap分区,此时进程不在内存中,而在磁盘上。
五、Linux中的其他进程状态
1. R(running):运行态
进程中的进程如果一直被运行,就会处于运行状态
源代码:
解析:此时我们要知道,我们在程序中写了一个死循环程序,虽然程序并没有执行什么内容,但是我们需要知道的是这个程序一直处于运行的状态
2. S(sleeping):睡眠状态
这种状态是一种阻塞状态,表示的是等待外设的就绪,是一种浅度睡眠状态,可以随时被中断
我们看到的现象是程序不断地输出,但是为啥是处于S状态呢??
原因很简单,主要是因为我们在程序的源代码中调用printf函数,这个函数是向终端输出内容的,是一种向慢设备输出的一个过程,因此,因为我们知道处理机的速度是非常快的,慢设备的速度是非常慢的,所以,这个过程中有90%的时间都是处于等待的过程,因此此时进程所属的状态是S状态
该状态属于浅度睡眠状态,可以随时被中断:
当然我们也可以采用kill -9 进程的pid
命令来杀掉该进程
3. D(disk sleeping):阻塞状态
属于一种深度睡眠的状态,这个状态一旦发生,就不容易被中断,一般情况下只能通过关机或者断电才能够中断,其发生本质原因是等待磁盘资源的分配,磁盘的资源压力过大
4. Z和X状态:死亡与僵尸
- X状态:表示进程已经死亡,处于终止态
- Z状态:表示进程处于僵尸状态,已经不用上处理机运行的状态
我们需要知道,在Linux中,一个进程退出时不会马上进入X态,而是会进入Z状态,那么这是为什么呢?
一个进程被创建就是为了完成某项任务,因此,当进程结束的时候,需要将进程的结束信息(是否完成任务等)告诉给父进程或者操作系统,也就是说:操作系统在一个进程退出后,这个进程不会马上处于X态,而是会为其维护一个称为僵尸态的状态,维护的目的是:就是维护进程的退出信息,以便将这个信息告知给操作系统或者父进程
如何模拟僵尸进程?
一般情况下,我们都会创建进程,这个进程会有相应的父进程,当子进程退出而父进程没有退出的时候,此时子进程所处的状态就是僵尸状态(Z状态)
此时可以看出,该进程处于僵尸状态
我们知道,一个进程处于僵尸状态的话,就说明其资源还没有被操作系统回收,那么长期如此,就会导致内存泄露,因此,当出现僵尸进程的时候,我们必须合理地解决好僵尸进程的问题
孤儿进程
当一个进程的父进程提前退出的时候,子进程还在运行,此时子进程会被父进程的父进程领养,即会被bash(1号进程)领养
此时我们会发现,这个进程的状态相比于上述的进程来说是没有+的,这种进程状态没有+,是不能被Ctrl+C杀掉的,此时必须使用kill -9 进程的pid
命令才能够杀掉进程
查看1号进程:使用top命令
从上图中我们可以看出,1号进程本质就是root,名为:systemd
5. T(Stopping):暂停状态
当进程被kill -19 pid
暂停的时候,此时进程会处于暂停状态
想要将进程进行恢复的话可以采用kill -18 pid
进行恢复
6.t(tracing stopping):追踪暂停状态
一般是在调试的过程中遇到断点的状态
总结
今天我们学习了操作系统中的各种进程状态,包括:运行态,终止态,阻塞态,挂起态,以及Linux系统中的各种进程状态:R(Running),S(sleeping),D(disk sleeping),Z(僵尸进程)和X(死亡态),T(stopping),t(trace stopping)