一、进程状态

1.创建状态
进程由创建而产生。创建进程是一个非常复杂的过程,一般需要通过多个步骤才能完成:如首先由进程申请一个空白的进程控制块(PCB),并向PCB中填写用于控制和管理进程的信息;然后为该进程分配运行时所必须的资源;最后,把该进程转入就绪状态并插入到就绪队列中。

2.就绪状态
这是指进程已经准备好运行的状态,即进程已分配到除CPU以外所有的必要资源后,只要再获得CPU,便可立即执行。如果系统中有许多处于就绪状态的进程,通常将它们按照一定的策略排成一个队列,该队列称为就绪队列。有执行资格,没有执行权的进程。

3.运行状态
这里指进程已经获取CPU,其进程处于正在执行的状态。对任何一个时刻而言,在单处理机的系统中,只有一个进程处于执行状态而在多处理机系统中,有多个进程处于执行状态。既有执行资格,又有执行权的进程。

4.阻塞状态
这里是指正在执行的进程由于发生某事件(如I/O请求、申请缓冲区失败等)暂时无法继续执行的状态,即进程执行受到阻塞。此时引起进程调度,操作系统把处理机分配给另外一个就绪的进程,而让受阻的进程处于暂停的状态,一般将这个暂停状态称为阻塞状态

5.终止状态
进程的终止也要通过两个步骤:首先,是等待操作系统进行善后处理,最后将其PCB清零,并将PCB空间返还给系统。当一个进程到达了自然结束点,或是出现了无法克服的错误,或是被操作系统所终结,或是被其他有终止权的进程所终结,它将进入终止状态。进入终止态的进程以后不能在再执行,但是操作系统中任然保留了一个记录,其中保存状态码和一些计时统计数据,供其他进程进行收集。一旦其他进程完成了对其信息的提取之后,操作系统将删除其进程,即将其PCB清零,并将该空白的PCB返回给系统。

  1. 为什么要分开就绪和阻塞状态

    答:因为就绪态只需要等待处理机,而阻塞态可能在等待输入输出,即使分配给处理机也是徒劳,所以两状态图不妥。对于调度进程,只需要等待就绪队列里的进程,因为阻塞状态可以转换到就绪队列里去。

  2. 进程五状态

  1. 新状态:进程已经创建,但未被OS接纳为可执行进程。(还没有申请到相应的资源)。

  2. 就绪态:进程做好了准备,准备执行(只等待处理机)。

  3. 执行状态:该进程正在执行(单处理机,某一时刻仅一个进程占用处理机)。

  4. 阻塞状态:等待某事件发生才能执行,如等待I/O完成。

  5. 终止状态.

  1. 问题:多个进程竞争内存资源

l 内存资源紧张

l 无就绪队列,处理机空闲:I/O速度比处理机速度慢的多,可能出现全部进程阻塞等待I/O。

解决方法

l 交换技术:换出一部分暂时不能运行的进程(阻塞进程)到外存(只换出程序和数据,PCB不换出去),以腾出内存空间,可以调用新进程来执行。

l 虚拟存储技术:每个进程只能装入一部分程序和数据

  1.  挂起:进程被交换到外存,状态变为挂起状态
    

4.1 进程挂起的原因(p91)

l 进程全部阻塞,处理机空闲。

l 系统负荷过重,内存空间紧张。(让其他进程先执行完)

l 操作系统的需要。操作系统可能需要挂起后台进程或一些服务进程,或者某些可能导致故障的进程。

l 终端用户请求。

l 父进程的需求。

4.2 挂起进程的特征

l 不能立即执行

l 可能是等待某事件发生,若是,则阻塞条件独立于挂起条件,即使阻塞事件发生,该进程也不能执行。

n 阻塞和挂起没有联系。

n 如果A进程现在要求输入数据,此时A进程属于阻塞状态,在选择挂起进程的时候,可能先选择阻塞进程(A进程),此时A进程挂起,正在输入数据,输入到内存缓冲区内。当数据输完了,向处理机发送命令数据已经输入完成,阻塞事件解除,但实际上还是挂起,所以仍是挂起态。

l 使之挂起的进程为:自身、父进程、OS。

l 只有挂起它的进程才能使之由挂起状态转换为其他状态。

4.3 阻塞与挂起

l 进程是否等待时间:阻塞与否。

l 进程是否被换出内存:挂起与否。

4.4 四种状态组合

l 就绪:进程在内存,准备执行。

l 阻塞:进程在内存,等待事件。

l 就绪/挂起:进程在外存,只要调入内存即可执行。

l 阻塞/挂起:进程在外存,等待事件。

4.5 处理机可调度执行的进程有两种

l 新创建的进程

l 或换入一个以前挂起的进程

通常为避免增加系统负载,系统会换入一个以前挂起的进程执行。

4.6 具有挂起状态的进程状态转换

l 阻塞 → 阻塞/挂起:OS通常将阻塞进程换出,以腾出内存空间

l 阻塞/挂起→ 就绪/挂起:当阻塞/挂起进程等待的事件发生时,可以将其转换为就绪/挂起。

l 就绪/挂起→ 就绪:OS需要调入一个进程执行。

l 就绪 → 就绪/挂起:一般,OS挂起阻塞进程。但是有时也会挂起就绪进程,释放足够的内存空间。

l 新 → 就绪/挂起(新→ 就绪):新进程创建后,可以插入到就绪队列或就绪,挂起队列,若无足够的内存分配给新进程,则需要新→ 就绪/挂起。

操作系统-进程状态转换图相关推荐

  1. 操作系统进程状态和状态转换详解

    主目录 ​ 之前的有博文对进程和线程的区别进行了详细的介绍,并且说明了引入进程的目的是为了能够使程序并发的执行,并且可以对并发执行的程序加以描述和控制.这篇博文,我们就来对进程的状态转换来进行详细的分 ...

  2. 操作系统--进程状态切换以及cpu调度(转)

    http://www.cnblogs.com/coder2012/p/3204730.html 进程的状态转换 进程在运行中不断地改变其运行状态.通常,一个运行进程必须具有以下三种基本状态. 进程状态 ...

  3. Linux下进程状态转换,Linux进程状态转换图

    Linux进程状态 Linux内核中的进程状态 ◆运行状态(TASK_RUNNING) 指正在被CPU运行或者就绪的状态.这样的进程被成为runnning进程.运行态的进程可以分为3种情况:内核运行态 ...

  4. 3.02 进程状态转换图

    进程状态是指操作系统中对进程进行管理时,为进程指定了几种状态.以便于给进程分配相应的资源. 最初只分了运行,等待,就绪三种状态. 运行态指的是这个进程所需要的所有资源都已经配足了,并且给它CPU资源, ...

  5. 操作系统进程状态模型

    操作系统中的进程有三个基本状态,分别是:就绪.运行.阻塞 就绪:万事俱备,只欠CPU 运行:正在执行 阻塞:进程因为等待某些事件的发生而处于等待状态 这三个状态合起来,就是操作系统的"三状态 ...

  6. 操作系统面试知识点总结2

    1.进程与线程 对于有线程系统: 进程是资源分配的独立单位 线程是资源调度的独立单位 对无无线程系统: 进程是资源调度.分配的独立单位 2.进程间的通信方式及优缺点 管道 有名管道:一种半双工的通信方 ...

  7. 操作系统面试知识点总结1

    一.进程与线程的概念,以及为什么要有进程线程,其中有什么区别,它们各自又是怎么同步的? 基本概念: 进程是对运行时程序的封装,是系统进行资源调度和分配的的基本单位,实现了操作系统的并发: 线程是进程的 ...

  8. 操作系统原理第五章:CPU调度

    目录 1 CPU调度基本概念 1.1 基本概念 1.2 CPU调度的时机 1.3 CPU调度方案 2 CPU调度算法 2.1 先来先服务(FCFS) 2.2 短作业优先(SJF) 2.3 优先级 2. ...

  9. 关于操作系统中进程、线程、死锁、同步、进程间通信(IPC)的超详细详解整理

    ​​​​​​​作者主页:https://www.zhihu.com/people/san-hao-bai-du-ren-79 一.什么是进程?什么是线程? 1.1 进程定义 1.2 线程定义 1.3 ...

最新文章

  1. ZIL (ZFS intent log) zil.c
  2. python字符串逆序_python之字符串逆序
  3. 百科园c语言题库第八章南信大,C语言上机题库百科园第3章!南信大!.doc
  4. (19)脚手架工具Yeoman
  5. Elasticsearch Restful API
  6. 电脑报制作黑客入门新手特训第1版
  7. ReactNative Ios打包流程
  8. linux 实时显示网速工具nload
  9. 金蝶ERP服务器系统中间件,中间件在ERP系统中的作用及发展趋势
  10. qq传输文件腾讯服务器保存在哪里,电脑接收的QQ文件在哪里?在哪个文件夹可以找到QQ接收的文件...
  11. 小程序结合腾讯地图(QQMapWX)SDK做位置周边搜索展示
  12. 如何快速查询京东快递物流正在派送中的单号
  13. 拆字在线版-扌斥字在纟戋片反【转】------字库增强版
  14. 腾讯云-即时通讯 IM
  15. Android 12 小部件详解
  16. 青岛大学计算机小姐姐,青岛大学举牌校花一夜爆红,评论区留下脏话:见不得别人好是病!...
  17. c语言解决方程的论文,c语言编程求解线性方程组论文1.doc
  18. 频率分辨率的一些分析
  19. 关于Jlink调试器JTAG和SWD的接口定义
  20. android分享助手下载地址,语音导出分享助手

热门文章

  1. echarts入门 堆叠折线图
  2. Git的使用:本地有新改动如何提交到远程服务器,仅做参考!
  3. 【宫水三叶的刷题日记】732. 我的日程安排表 III
  4. Simulink模型颜色快速设置
  5. 五年Java开发者小米、阿里面经
  6. linux怎么验证tacacs认证,TACACS+认证服务器总结
  7. 计算机网络——网络层课后习题答案
  8. 类脑科学实验(四)——LSTM的实现
  9. html5---nav标签
  10. 基于深度学习的高精度奶牛检测识别系统(PyTorch+Pyside6+YOLOv5模型)