[Linux] Linux操作系统 进程的状态

 标题:[Linux] Linux操作系统 进程的状态

个人主页:@水墨不写bug

(图片来源于网络)

目录

 一、前置概念的理解

1.并行和并发

2.时间片 

 3.进程间具有独立性

 4.等待的本质


正文开始:

        在校的时候,你一定学过《操作系统原理》这本书,操作系统这个学科作为计算机哲学科目,无疑非常难以理解。再加上操作系统原理这本书并不是针对某一种操作系统而写的书,所以其内的大多数解释概念解释 含糊不清,难以琢磨。这不是作者的原因,而是选题的原因:因为它讲的是操作系统这个抽象后的概念,对于某一种具体的操作无法落实到具体的事例,什么意思呢?

        比如,MacOS,Windows,Linux对于某一概念本质是一样的,但是处理方法不同,于是操作系统原理就笼统的用提取出来的概念来讲。再比如,模板大家都知道吧,《操作系统原理》这本书就好比是仅仅是对着模板来讲解,而不是一个具体的函数。一般而言,我们理解模板的正常逻辑是从一个具体函数然后上升到对模板的理解的,是从具体到抽象的过程,而不是仅仅停留在模板,只讲抽象的概念。

         这也就是你觉得操作系统难的原因。本文就沿着Linux这一具体的操作系统来讲解操作系统的概念。之所以选择Linux,是因为Linux是最受欢迎的高效、免费的操作系统,企业级应用最多。


         在理解进程的概念之前,我们需要先铺垫几个重要的概念:

 一、前置概念的理解

1.并行和并发

        并发:假设我们只有一个低配置的单核的CPU,这个时候我们仍然是可以启动多个进程的,为什么呢?这就是并发;

        CPU执行进程代码,不是把进程代码执行完,才开始执行下一个,而是给每一个进程预分配一个时间片,基于时间片,依次调度各个进程,进行调度轮转,这就是并发。即便只有一个CPU,这一个CPU仍然可以凭借并发,来在人眼无法分辨的时间段内极速切换,达到“同时”运行多个进程的目的。

        并行:多个进程在多个CPU下分别同时进行,称为并行


2.时间片 

        在Linux操作系统中,时间片(Time Slice)是操作系统进行  进程调度  时分配给每个进程运行的一段固定时间。Linux(以及许多其他现代操作系统)使用基于时间片的轮转调度算法(Round-Robin Scheduling)来管理CPU资源的分配,以确保所有进程都能公平地获得执行时间。

        当一个进程被调度到CPU上运行时,它会被分配一个时间片。在这个时间片内,进程可以执行其任务。当时间片结束时,无论该进程是否已经完成其工作,操作系统都会暂停该进程的执行,并将其放回就绪队列的末尾(或根据调度算法的其他规则重新排序)。然后,操作系统会选择另一个进程来执行,为其分配一个新的时间片。

        对于大多数民用级Linux/Windows操作系统,使用的是分时操作系统,也就是上面的这种采用时间片调度的操作系统。而对于一些特殊需求的高精度,高需求的场景:比如航空航天,车辆自动驾驶等,就不能再使用分时操作系统,因为毫秒级别的误差就可能导致事故。这些场景就需要采用实时操作系统


 3.进程间具有独立性

         进程间具有很强的独立性,这里目前不需要很深的理解。

        父进程创建的子进程挂掉之后,父进程不会收到影响,比如你在本地IDE上写一个程序,但是出现空指针导致程序挂掉了,你写的进程结束了,但是IDE不会因此挂掉。

 4.等待的本质

         在Linux下,进程有许多种不同的状态,之所以为进程区分状态,是为了提高效率。一个进程实际并没有用到CPU资源,但是却占用内存,这样的做法显然不合理。

        Linux进程的状态有:

/*
* The task state array is a strange "bitmap" of
* reasons to sleep. Thus "running" is zero, and
* you can test for combinations of others with
* simple bit tests.
*/
static const char * const task_state_array[] = {
"R (running)", /* 0 */
"S (sleeping)", /* 1 */
"D (disk sleep)", /* 2 */
"T (stopped)", /* 4 */
"t (tracing stop)", /* 8 */
"X (dead)", /* 16 */
"Z (zombie)", /* 32 */
};

总体介绍:

        CPU根据一定的调度算法依次调度每一个进程。

        运行的或者是准备好的进程处于运行队列中。只要进程在运行队列中,该进城就处于运行状态,表示:“进程已经准备好了,可以随时被CPU调度进行运算”

        当一个进程被阻塞的时候,这个进程就不需要被放入运行队列中,因为它不需要被CPU调度。 那么这个进程就会被加载到不同的硬件的数据结构中,等待硬件的响应,这个时候的进程就处于睡眠状态。

        睡眠状态根据进程重要程度的不同,分为可中断睡眠和不可中断睡眠。

运行和阻塞的本质:

是让不同的进程处在不同的队列中。

       

 R运行状态(running) : 并不意味着进程一定在运行中,它表明进程要么是在运行中要么在运行队列里。

S睡眠状态(sleeping): 意味着进程在等待事件完成(这里的睡眠有时候也叫做可中断睡眠(interruptible sleep))

D磁盘休眠状态(Disk sleep):有时候也叫不可中断睡眠状态(uninterruptible sleep),在这个状态的进程通常会等待IO的结束。

T停止状态(stopped): 可以通过发送 SIGSTOP 信号给进程来停止(T)进程。这个被暂停的进程可以通过发送 SIGCONT 信号让进程继续运行。

X死亡状态(dead):这个状态只是一个返回状态,你无法在任务列表里看到这个状态


完~

未经作者同意禁止转载

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

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

相关文章

10 张手绘图详解Java 优先级队列PriorityQueue

PriorityQueue 是 Java 中的一个基于优先级堆的优先队列实现,它能够在 O(log n) 的时间复杂度内实现元素的插入和删除操作,并且能够自动维护队列中元素的优先级顺序。 通俗来说,PriorityQueue 就是一个队列,但是它不是先进先出的…

【速成Redis】04 Redis 概念扫盲:事务、持久化、主从复制、哨兵模式

前言: 前三篇如下: 【速成Redis】01 Redis简介及windows上如何安装redis-CSDN博客 【速成Redis】02 Redis 五大基本数据类型常用命令-CSDN博客 【速成Redis】03 Redis 五大高级数据结构介绍及其常用命令 | 消息队列、地理空间、HyperLogLog、BitMap、…

带你0到1之QT编程:十五、探索QSplitter和QDockWidget的简单应用技巧

此为QT编程的第十五谈!关注我,带你快速学习QT编程的学习路线! 每一篇的技术点都是很很重要!很重要!很重要!但不冗余! 我们通常采取总-分-总和生活化的讲解方式来阐述一个知识点! …

系统架构设计师 - 案例特训专题 - 软件工程篇

案例特训专题 - 软件工程篇 软件工程篇需求分析 ★★★★结构化需求分析 SA数据流图答题技巧 面向对象设计 ★★UML 图概况用例图类图与对象图顺序图通信图状态图活动图定时图构件图包图部署图 大家好呀!我是小笙,本章我主要分享系统架构设计师 - 案例特…

【刷题—双指针】复写0、三数之和、四数之和

目录 一、复写0二、三数之和三、四数之和 一、复写0 题目: 注意:题目要求是原数组上复写 思路: 一、确定最后一个复写的位置。定义两个变量cur等于0,dest等于-1,让cur去遍历数组。如果cur指向的元素是0,…

【玉米田】

题目 代码 #include <bits/stdc.h> using namespace std; typedef long long LL;const int mod 1e8; const int M 1 << 12; LL f[13][M]; int g[13]; vector<int> state; vector<int> p[M]; int n, m; bool check(int x) {return !(x & x <&…

【Linux课程学习】make/Makefile:Linux项目自动化构建工具

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;Linux课程学习 &#x1f337;追光的人&#xff0c;终会万丈光芒 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 &#x1f349;一.make/Makefile的理解&#xff1a; …

基于SpringBoot+Vue+MySQL的国产动漫网站

系统展示 用户前台界面 管理员后台界面 系统背景 随着国内动漫产业的蓬勃发展和互联网技术的快速进步&#xff0c;动漫爱好者们对高质量、个性化的国产动漫内容需求日益增长。然而&#xff0c;市场上现有的动漫平台大多以国外动漫为主&#xff0c;对国产动漫的推广和展示存在不…

【Java集合】深入了解ArrayList实现原理

概述 1.数据存储是基于动态数组实现的&#xff0c;默认初始容量为10。 2.添加数据时&#xff0c;首先需要检查元素个数是否超过数组容量&#xff0c;如果超过了则需要对数组进行扩容&#xff08;1.5倍&#xff09;&#xff1b;插入数据时&#xff0c;需要将从插入点 k 开始到数…

BMC 虚拟i2c访问PCA9545(switch芯片)后面的设备,为什么找不到PCA9545?

1.说明 1.1 背景 无意中看到PCA9545(switch芯片)后面有设备&#xff0c;但是PCA9545设备本身是连接到物理设备i2c上的&#xff0c;然而扫描该物理i2c bus&#xff0c;却找不到该设备。此篇文章主要找一下该原因的。 1.2 参考代码 当前使用的是ast2600芯片&#xff0c;可参考…

java使用ByteBuffer进行多文件合并和拆分

1.背景 因为验证证书的需要&#xff0c;需要把证书文件和公钥给到客户&#xff0c;考虑到多个文件交互的不便性&#xff0c;所以决定将2个文件合并成一个文件交互给客户。刚开始采用字符串拼接2个文件内容&#xff0c;但是由于是加密文件&#xff0c;采用字符串形式合并后&…

threejs性能优化之gltf文件压缩threejs性能优化之glb文件压缩

在使用Three.js进行3D图形开发时&#xff0c;GLTF&#xff08;GL Transmission Format&#xff09;文件因其高效性和灵活性而广受欢迎。然而&#xff0c;随着模型复杂度的增加&#xff0c;GLTF文件的大小也会显著增加&#xff0c;这可能会对加载时间和渲染性能产生负面影响。为…

Redis数据结构之哈希表

这里的哈希表说的是value的类型是哈希表 一.相关命令 1.hset key field value 一次可以设置多个 返回值是设置成功的个数 注意&#xff0c;哈希表中的键值对&#xff0c;键是唯一的而值可以重复 所以有下面的结果&#xff1a; key中原来已经有了f1&#xff0c;所以再使用hse…

linux 操作系统下dhcrelay命令介绍和案例应用

linux 操作系统下dhcrelay命令介绍和案例应用 dhcrelay是一个用于DHCP&#xff08;动态主机配置协议&#xff09;中继的命令&#xff0c;主要功能是在没有本地DHCP服务器的子网中转发DHCP请求。这使得不同子网的DHCP客户端能够与位于其他子网中的DHCP服务器进行通信。 dhcrela…

基于微信小程序的购物系统+php(lw+演示+源码+运行)

基于微信小程序的购物系统 摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了基于微信小程序的购物系统的开发全过程。通过分析基于微信小程序的购物系统管理的不足&#xff0c;创建了一个计算机管理基于微信小…

如何使用 Python 连接 MySQL 数据库?什么是 ORM(对象关系映射),如何使用

数据库是现代软件开发中的核心部分&#xff0c;而 Python 作为一种流行的编程语言&#xff0c;广泛应用于数据处理和分析工作。通常我们需要通过 Python 连接数据库并执行一些常见的操作&#xff0c;如插入、查询、更新和删除数据。在实际开发中&#xff0c;MySQL 是非常常用的…

LeetCode[中等] 155. 最小栈

设计一个支持 push &#xff0c;pop &#xff0c;top 操作&#xff0c;并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。void push(int val) 将元素val推入堆栈。void pop() 删除堆栈顶部的元素。int top() 获取堆栈顶部的元素。int get…

线程知识点补充

我们之前&#xff1a; 主线程下来&#xff0c;调用了一个方法run方法&#xff0c;方法执行完后再继续往下走主线程。 咱们期望&#xff1a; 两个同时执行&#xff0c;交替执行。 一些核心概念说明&#xff1a; 一个程序写好是静态的&#xff0c;给他运行起来就是一个进程了…

java计算机毕设课设—土地档案管理系统(附源码、文章、相关截图、部署视频)

这是什么系统&#xff1f; 资源获取方式在最下方 java计算机毕设课设—土地档案管理系统(附源码、文章、相关截图、部署视频) 土地档案管理系统是一种将传统纸质档案进行数字化管理的软件。通过该系统&#xff0c;用户能够高效地进行土地档案的存储、查阅、修改和删除等操作…

unity3d入门教程八-飞机大战

unity3d入门教程八-飞机大战 19.2竖屏设置19.3主控脚本19.4制作子弹19.5制作飞机19.6制作怪物19.7击中目标19.8随机生成怪物19.9预制体怪物随机更换头像19.10怪物相关优化19.11游戏背景19.12游戏最终优化一、 HP显示二、怪物预制体三、分值显示四、背景音乐 19.2竖屏设置 切换到…