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

news2024/11/22 10:21:33

前言

大家好吖,欢迎来到 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.coloradmin.cn/o/1532071.html

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

相关文章

cmd中cd命令无法进入文件目录

问题:在cmd中用cd命令进入不了目录 解决办法:在cd后面加/d(cd和/d之间有空格) windows的cmd命令cd和cd /d的区别: 1. cd 命令: - cd 是 "change directory" 的缩写。 - 默认情况下,cd 命令…

DNA存储技术原理是什么?

随着大数据和人工智能的发展,全球每天产生的数据量剧增,对存储设备的需求也随之增长,数据存储问题日益凸显。传统的硬盘驱动器(HDD)、磁带等冷存和深度归档存储占据数据中心存储的60-70%,由于它们的访问频率…

Java特性之设计模式【组合模式】

一、组合模式 概述 组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模式&#x…

【YUNBEE云贝-PostgreSQL】FDW应用

注: 本文为云贝教育 刘峰 原创,请尊重知识产权,转发请注明出处,不接受任何抄袭、演绎和未经注明出处的转载。 前言 Wrapper(FDW)是一项关键特性,它赋予数据库用户直接通过SQL语句访问存储于外部数据源的能…

Jumpserver 堡垒机用户启用双因子登录

前言: 堡垒机双因子登录 堡垒机往往是内部权限的集合体,拿到了堡垒机的用户账号密码,很容易就顺藤摸瓜攻破各种应用系统,除了常规的用户名复杂密码的要求外,我们常常都要求采用双因子的登录方式。双因子最常见的就是账…

【Super数据结构】先进先出/后进先出,队列和栈代码实现+应用场景

🏠关于此专栏:Super数据结构专栏将使用C/C语言介绍顺序表、链表、栈、队列等数据结构,每篇博文会使用尽可能多的代码片段图片的方式。 🚪归属专栏:Super数据结构 🎯每日努力一点点,技术累计看得…

HarmonyOS如何使用低代码实现界面布局

介绍 本篇Codelab是基于ArkTS语言的低代码开发方式实现的一个简单实例。具体实现功能如下: 创建一个低代码工程。通过拖拽的方式实现任务列表和任务信息界面的界面布局。在UI编辑界面实现数据动态渲染和事件的绑定。 最终实现效果如下: 相关概念 低代…

ECharts5 概念篇2

数据转换 数据转换基础使用 在 echarts 中,数据转换是依托于数据集(dataset)来实现的. 我们可以设置 dataset.transform 来表示,此 dataset 的数据,来自于此 transform 的结果。下面是上述例子的效果,三个饼…

冶炼金属(二分)

题目描述: 小蓝有一个神奇的炉子用于将普通金属 O 冶炼成为一种特殊金属 X。 这个炉子有一个称作转换率的属性 V,V是一个正整数,这意味着消耗 V个普通金属 O 恰好可以冶炼出一个特殊金属 X,当普通金属 O 的数目不足 V 时&#x…

【机器学习】基于粒子群算法优化的BP神经网络分类预测(PSO-BP)

目录 1.原理与思路2.设计与实现3.结果预测4.代码获取 1.原理与思路 【智能算法应用】智能算法优化BP神经网络思路【智能算法】粒子群算法(PSO)原理及实现 2.设计与实现 数据集: 多输入多输出:样本特征24,标签类别4…

项目五 实现对学生信息的简单查询

项目五 实现对学生信息的简单查询 1,查询数据库中部分字段的信息 使用select语句对表的选择及连接等操作,结构会生成一个临时表,将select结果存放到临时表中 查询数据表中所有字段的值 #格式:(*:表示所有列) select * from 表…

milvus安装

milvus安装 sudo curl -L “https://github.com/docker/compose/releases/download/1.29.2/docker-compose- $ (uname -s)- $ (uname -m)” -o /usr/local/bin/docker-compose sudo chmod x /usr/local/bin/docker-compose sudo ln -s /usr/local/bin/docker-compose /usr/bin/…

SpringBoot项目通过触发器调度实现定时任务

文章目录 前言一、quartz是什么?二、quartz中核心概念三、集成步骤1.引入依赖2.demo样例a.定义一个任务参数实体类b.定义操作触发器、定时任务接口及实现c.作业实现d.结果截图 四、其他1.QuartzJobBean和Job区别2.注意事项3.作业(Job)和触发器…

考虑功率均分与电压频率的事件触发分布式二次控制MATLAB模型

微❤关注“电气仔推送”获得资料(专享优惠) 模型简介 此模型是在《基于事件触发机制的孤岛微电网二次电压与频率协同控制MATLAB仿真模型》上进一步创作的,之前的模型只考虑了二次电压与频率控制,并没有考虑均分这一项点。 因此…

STM32相关资料汇总

STM32选型表 STM32手册参考网站 https://www.stmcu.org.cn/

文件包含漏洞之包含NGINX日志文件(常用)

条件:知道目标服务器的日志文件存贮路径,并且存在文件包含漏洞 首先对目标服务器发送一次含有木马的请求,目的是让目标服务器日志中生成含有木马的日志记录。因为发送过程中,使用了url编码,我们抓包进行更改成能够执行…

网络——入门基础

目录 协议 网络协议 OSI七层模型 网络传输基本流程 网络传输流程图 局域网通信 数据包的封装和解包 广域网通信 网络地址管理 IP地址 MAC地址 协议 关于什么是局域网,什么是广域网,我这里就不过多赘述了,我们直接来谈一下什么…

复旦发布层次性奖励学习框架,增强大模型人类偏好对齐

在人工智能领域,强化学习(Reinforcement Learning, RL)一直是实现智能体自主学习的关键技术之一。通过与环境的交互,智能体能够自我优化其行为策略,以获得更多的奖励。然而,当涉及到复杂的人类偏好时&#…

codeforces 1600分

文章目录 1.[G. Special Permutation](https://codeforces.com/problemset/problem/1352/G)2.[D. Constructing the Array](https://codeforces.com/problemset/problem/1353/D)3.[C2. k-LCM (hard version)](https://codeforces.com/problemset/problem/1497/C2)4.[C. Circle …

【ollama】linux、window系统更改模型存放位置,全网首发2024!

首先是window系统 so easy 直接进入系统环境变量添加就行 其次是linux系统 全靠自己试出来的,去Ollama官网找半天文档不知道在哪,而且linux也没有说:【 https://github.com/ollama/ollama/blob/main/docs/README.md https://github.com/o…