【Linux】盘点广义层面上【三种最基本的进程状态】

前言

大家好吖,欢迎来到 YY 滴 Linux系列 ,热烈欢迎! 本章主要内容面向接触过Linux的老铁
主要内容含:
在这里插入图片描述

欢迎订阅 YY滴C++专栏!更多干货持续更新!以下是传送门!

  • YY的《C++》专栏
  • YY的《C++11》专栏
  • YY的《Linux》专栏
  • YY的《数据结构》专栏
  • YY的《C语言基础》专栏
  • YY的《初学者易错点》专栏
  • YY的《小小知识点》专栏
  • YY的《单片机期末速过》专栏
  • YY的《C++期末速过》专栏
  • YY的《单片机》专栏
  • YY的《STM32》专栏
  • YY的《数据库》专栏
  • YY的《数据库原理》专栏

目录

  • 一.进程状态变化の本质原理
  • 二.操作系统层面的三种广义进程状态
    • 1.运行状态
    • 2.阻塞状态
    • 3.挂起状态

一.进程状态变化の本质原理

PS:我们大致知道就可以,理解在下文

引入: 下面以Linux操作系统中的状态举例,不同系统或多或少会有差别

  • R运行状态(running) : 并不意味着进程一定在运行中,它表明进程要么是在运行中要么在运行队列里。
  • S睡眠状态(sleeping) : 即广义上的“阻塞状态” 。意味着进程在等待事件完成(这里的睡眠有时候也叫做可中断睡眠(interruptible sleep))
  • D磁盘休眠状态(Disk sleep): 有时候也叫不可中断睡眠状态(uninterruptible sleep),在这个状态的进程通常会等待IO的结束。
  • T停止状态(stopped): 可以通过发送 SIGSTOP 信号给进程来停止(T)进程。这个被暂停的进程可以通过发送 SIGCONT 信号让进程继续运行。
  • X死亡状态(dead):这个状态只是一个返回状态,你不会在任务列表里看到这个状态

原理:

  • 操作系统中有许多 队列 :运行队列,阻塞队列,设备等待队列…
  • 进程状态:就是PCB中的一个字段,就是PCB中的一个 整型变量
  • 所谓的 状态变化的本质 本质就是修改整型变量 并将对应的PCB放到各种队列中
  • 宏定义了各种状态
#define NEW 1
#define RUNNING 2
#define BLOCK 3
  • 通过对PCB中 相应字段的赋值 ,从而实现各种进程操作
PCB->status == BLOCK           if(PCB->status == NEW)              //PCB放入运行队列
else if (PCB->status == BLOCK)           //PCB放入阻塞队列

二.操作系统层面的三种广义进程状态

1.运行状态

  • 每一个CPU在系统层面都会维护一个 运行队列
  • 运行队列: 我们运行程序创建进程时,会生成PCB;
  • 而我们的运行队列中有头节点,可以穿起这些PCB,从而实现运行的先后
  • 只要在运行队列中的进程 ,它的状态都是 运行状态 (代表我已经准备好了,可以随时被调度)

2.阻塞状态

  • 我们的代码中,一定会或多或少 访问系统中的某些资源!
  • 例如:scanf()/ cin>>,我们要从键盘中接收数据
  • 而如果我们一直不输入,就代表 我们进程要访问的资源 没有就绪
  • 最终结果是:进程代码 无法继续向后执行
  • 而我们知道:操作系统会对驱动程序,底层硬件进行 管理 (先描述,后组织——会有各种数据结构)
  • 操作系统内部,会以类似PCB的形式,创建各种设备特有的结构体;
  • 并且他们能够以 链表 形式被串起来,也就是我们俗称的 设备列表
  • 对设备的管理,同时也变成了对链表的增删查改
  • 操作系统中有许多队列,运行队列…
  • 而在上面我们知道的每个设备结构体中,都维护了一个 wait_queue等待队列

重点

  • 而我们进程代码无法继续向后执行时,我们就会把 没有就绪的PCB 移动到未响应的设备(键盘)的 wait_queue等待队列中
  • 这个状态就是 阻塞状态
  • 阻塞状态 的本质: PCB不在运行队列中,而在设备的等待队列中
  • PCB同时也可以在其他PCB的等待队列中

3.挂起状态

  • 如果一个进程当前被 阻塞 了,注定这个进程在他等待的资源没有就绪的时候,该进程无法被调度
  • 而如果此时,恰好OS的 内存资源已经严重不足了,该怎么办?
  • 挂起状态的本质 操作系统把在内存中的进程(代码和数据)置换到磁盘中(SWAP分区)
    在这里插入图片描述
  • 操作系统会优先挂起阻塞的进程,因此也叫: 阻塞挂起
  • 这种挂起状态,会造成系统效率变低
  • 在设计操作系统时,会避免将用于置换PCB的SWAP分区设置过大,防止操作系统过于依赖挂起;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/758757.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL语句之SELECT语句

一般格式 SELECT DISTINCT/ALL 目标列表达式 //要显示的属性列 FROM 表名/视图名 //查询的对象 WHERE 条件表达式 //查询条件 GROUP BY 列名 HAVING 条件表达式 //查询结果分组 ORDER BY 列名 次序; //最终查询结果排序 文章目录 一、基本查询 1、SELECT 目标列表达…

进程(2)——进程优先级

1、基本概念 cpu资源分配的先后顺序,就是指进程的优先权(priority)。 优先权高的进程有优先执行权利。配置进程优先权对多任务环境的linux很有用,可以改善系统性能。 还可以把进程运行到指定的CPU上,这样一来&a…

Spring MVC开发小练习

1. 加法计算器 需求:输入两个整数,计算和 约定前后端交互接口: 在开发项目前,根据需求先约定好前后端交互接口,双方按照接口文档进行开发,接口文档一旦写好,尽量不要轻易改变,如果…

Springboot+vue的船舶维保管理系统(有报告)。Javaee项目,springboot vue前后端分离项目。

演示视频: Springbootvue的船舶维保管理系统(有报告)。Javaee项目,springboot vue前后端分离项目。 项目介绍: 采用M(model)V(view)C(controller&#xff09…

2024最新自动化测试面试题合集 (附答案)

1、你会封装自动化测试框架吗? 这个问得最多,甚至有很多公司直接写在招聘要求中! 当然可以,自动化框架主要的核心框架就是分层PO模式:分别为:基础封装层BasePage,PO页面对象层,Tes…

网络编程-DAY6

1>创建一个武器信息库,包含编号(主键)、名称、属性、描述、价格 2>添加三把武器 3>修改某把武器的价格 4>展出价格在1000到4000的武器 5>卖掉一把武器,删除该武器的信息 6>几天后,客户顶着光头…

在Rust中,探索word到pdf的转换

word到pdf的转换看起来已经成熟,但是在特定的业务场景下,现有的转换仍然有万分之几的出错率,这个数字,在苛刻的商业环境下,也是不能接受的。因此,有必要探索一下word到pdf的转换。 在Rust中,直…

HarmonyOS NEXT应用开发之左右拖动切换图片效果案例

介绍 本示例使用滑动手势监听,实时调整左右两侧内容显示区域大小和效果。通过绑定gesture事件中的PanGesture平移手势,实时获取拖动距离。当拖动时,实时地调节左右两个Image组件的宽度,从而成功实现左右拖动切换图片效果的功能。…

强森算法求两点最短路径的基本流程及代码实现

对于强森算法,给定的一个图中,算法首先会构造一个新的节点s,然后从新构造的这个节点引出多条边分别连通图中的每一个节点,这些边的长度一开始是被设置为0的,然后使用贝尔曼-福德算法进行计算,算出从s到图中每一个节点的最短路径。 而在运行贝尔曼-福德算法的过程中如果发…

机器学习之无监督学习简介及算法库推荐

文章目录 无监督学习概述无监督学习定义无监督学习与有监督学习的区别 算法库推荐无监督学习的主要算法聚类算法K-means算法 降维算法PCA算法 聚类算法详解K-means算法算法步骤: DBSCAN算法算法步骤: 降维算法详解主成分分析(PCA)原理代码示例 t-SNE算法…

C语言之动态内存管理(快点进来!!!)

c语言中的小小白-CSDN博客c语言中的小小白关注算法,c,c语言,贪心算法,链表,mysql,动态规划,后端,线性回归,数据结构,排序算法领域.https://blog.csdn.net/bhbcdxb123?spm1001.2014.3001.5343 给大家分享一句我很喜欢我话: 知不足而奋进,望远山而前行&am…

2024全国水科技大会【联合主办】福州水务集团有限公司

福州水务成立于2008年11月,AA信用评级,注册资本21.2亿元。下属各级企业70多家(包括3家国家级高新技术企业、1家A股上市企业)。集团主营供水、排水、环保、温泉文旅、综合服务五大板块,旗下运营自来水厂17座&#xff0c…

【WSL】Ubuntu 20.04 字符集不认识中文,及其中文路径

1. 问题 $ locale locale: Cannot set LC_CTYPE to default locale: No such file or directory locale: Cannot set LC_ALL to default locale: No such file or directory LANGen_US.UTF-8 LANGUAGE LC_CTYPEUTF-8 LC_NUMERIC"en_US.UTF-8" LC_TIME"en_US.UT…

算法沉淀——贪心算法五(leetcode真题剖析)

算法沉淀——贪心算法五 01.跳跃游戏 II02.跳跃游戏03.加油站04.单调递增的数字 01.跳跃游戏 II 题目链接:https://leetcode.cn/problems/jump-game-ii/ 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转…

redis在springboot项目中的应用

一,将查询结果放到redis中作为缓存,减轻mysql的压力。 只有在数据量大的时候,查询速度慢的时候才有意义。 本次测试的数据量为XXX. 测试代码: 功能为根据昵称进行模糊匹配。 GetMapping("/get-by-nick")public String getNickN…

维度建模理论之事实表

事实表概述 事实表作为数据仓库维度建模的核心,紧紧围绕着业务过程来设计。其包含与该业务过程有关的维度引用(维度表外键)以及该业务过程的度量(通常是可累加的数字类型字段)。 事实表特点 事实表通常比较“细长”…

Node.js核心命令与工具:提升开发效率的实用指南

🌟 前言 欢迎来到我的技术小宇宙!🌌 这里不仅是我记录技术点滴的后花园,也是我分享学习心得和项目经验的乐园。📚 无论你是技术小白还是资深大牛,这里总有一些内容能触动你的好奇心。🔍 &#x…

Redis面试题以及答案

1. 什么是Redis?它主要用来什么的? Redis,英文全称是Remote Dictionary Server(远程字典服务),是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并…

Python基础入门 --- 7.函数

Python基础入门 第七章: 7.函数 7.1 函数多返回值 按照返回值顺序,写对应顺序的多个变量接收,变量之间用逗号分隔,支持不同数据类型return def test_return():return 1,"hello", Truex, y, z test_return() print…

刷力扣看见一个寻找单身狗的问题?【力扣题解】

今天刷力扣遇到一道有意思的题目,题目是写着撞色问题177 ,当我写完这个题去看看有什么好的解题方式的时候,看见一个有趣的题解问题,他对这个题目的描述是几对情侣,带几个单身狗出去玩,然后现在我们要把这几…