Linux之创建进程、查看进程、进程的状态以及进程的优先级
文章目录
- 前言
- 一、初识fork
- 1.演示
- 2.介绍
- 3.将子进程与父进程执行的任务分离
- 4.多进程并行
- 二、进程的状态
- 1.进程的状态都有哪些?
- 2.查看进程的状态
- 2.运行(R)
- 3.阻塞
- 4.僵尸进程(Z)
- 1.僵尸状态概念
- 2.为什么要有僵尸状态?
- 3.僵尸状态的例子
- 3.僵尸状态的危害
- 5.孤儿进程
- 三、进程的优先级
- 1.优先级概念
- 1.权限与优先级
- 2.什么是优先级
- 3.为什么存在优先级
- 4.特性
- 2.查看系统进程
- 3.PRI和NI
- 4.修改进程的优先级
- 总结
前言
本文介绍了创建进程、查看进程、进程的状态以及进程的优先级相等关概念
一、初识fork
通过系统调用fork创建子进程。
1.演示
文件test.c
运行结果:
2.介绍
fork的头文件为unistd.h
fork的返回值:父进程会返回子进程的pid,子进程返回0(一个子进程只有一个父进程,但是有个父进程可以有无数个子进程,一次要将子进程的pid返回给父进程,而子进程不需要)
3.将子进程与父进程执行的任务分离
根据父子进程的返回值不同:
文件test.c
运行结果:
4.多进程并行
文件test.c
运行结果:
二、进程的状态
1.进程的状态都有哪些?
进程的状态有很多:运行、就绪、挂起、阻塞等等。
进程有这么多不同的状态,本质上是为了满足不同的运行场景。
具体的进程状态:
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 */
};
-
R运行状态(running):并不意味着进程一定在运行状态,他只是表明进程在运行队列里。
-
S睡眠状态(sleeping):意味着进程正在等待时间完成(这里的睡眠也成为可中断睡眠/浅度睡眠(interruptible sleep))。
例子:进程从运行到访问外设再到访问外设完毕这段时间进程处于睡眠状态。 -
D磁盘休眠状态(Disk sleep):也叫做不可中断睡眠状态,该状态的进程通常会等待I/O的结束。该进程不能被操作系统kill掉。
例子:某一个进程向磁盘发布了写东西的任务(例如:要求写0~100到文件上),那么磁盘就会去完成这个任务,此时进程处于等待状态。如果恰好操作系统内的资源紧缺,操作系统有权利自主杀掉一些不干事情的进程(未处于运行状态),该进程就会被操作系统杀死。由于外设的运行速度很慢,等到外设完成任务回来寻找对应的进程交代任务结果时,发现该进程无法被唤醒(该进程已经被杀死了),这就会导致磁盘内对应数据的丢失。因此,为了避免这种情况出现,我们将一些特殊的进程赋予D状态(相当于免死金牌,避免操作系统将它杀死),这样它只能等对应的I/O完成才会重新变为其他状态。 -
T停止状态(stopped):可以通过发送SIGSTOP信号给进程来停止进程(该进程处于T状态),然后可以给这个被暂停的状态发送SIGCONT信号,让该进程继续运行(当一个前台进程被暂停后,又被恢复继续运行时,前台进程会转为后台进程,此时进程无法被ctrl + c终止,只能用kill -9 (进程pid)终止进程)。
-
X死亡状态(dead):该状态只是一个返回状态,不会在任务列表中看到这个状态。
-
还有两个特殊的状态:僵尸状态和孤儿状态在后续内容会详细讲解。
2.查看进程的状态
ps aux
或者 ps ajx
命令可以查看进程的状态。
2.运行(R)
- 一个CPU一个运行时队列;
- 让进程进入运行时队列,本质是将该进程的task_struct结构体放入运行队列中;
- 进程PCB在runqueue时,该进程就是运行状态(R),而不是该进程在运行时才算;(CPU很快,可以将运行队列中的进程很快的过一遍,因此运行队列里都是处于运行状态)
状态 ->进程内部的属性 -> task_struct -> int(1:run ; 2:run ; 3:run ; 4:run),进程的状态本质就是进程PCB中的一个整型值。 - 不要以为只有CPU会被多进程访问,硬件设备也是稀缺资源,也会被多进程访问。
- 所谓的进程的不同状态,本质是进程在不同的队列中等待某种资源(将task_struct结构体对象放入不同的的等待队列)。
3.阻塞
- 外设硬件的访问速度是很慢的(相对CPU),但是进程或多或少都需要访问它,但是在多进程同时访问硬件设备时,也只有少量的进程(竞争力强的)可以访问到它。
- 当有其他进程在访问该设备时,其他进程只能等待。等待中的进程将从运行时队列中取出,放入该设备对应的阻塞(等待)队列中,此时该进程处于阻塞状态。
- 等到设备空余出来(没有进程访问的时候),OS会知道它好了,然后OS就会等待的该进程的状态由阻塞改为运行(R),在将该进程放入运行时队列即可机械运行。
4.僵尸进程(Z)
1.僵尸状态概念
一个小栗子
一天,张三在路上跑步,突然路边有一个人死亡了,张三立刻打电话给警察局,那么在这个路人死亡的那一瞬间直到警察查明他的信息以及死亡原因的这一过程就相当于处于僵尸状态(死了,但是别人不知道他死了)。
- 当子进程退出,但是父进程没有(通过
wait()
系统调用)读取子进程的退出状态代码时,就会导致子进程处于僵尸状态。 - 僵尸进程会议终止状态保持在进程表中,并且一直等待父进程读取退出状态代码。
- 因此,只要子进程退出,父进程还在匀称并且没有读取子进程的状态,子进程就进入僵尸状态。
2.为什么要有僵尸状态?
进程被创建是为了完成分配给他的任务,当然生活中有些事情需要返回结果,有些事情不需要,但是作为一个程序它无论你需不需要知道结果,它都得将任务的执行情况返回。程序退出时不能立即释放程序中的所有资源,而是需要保持一段时间,让父进程/OS读取它的退出代码。
退出程序和释放程序的资源之间的一段时间程序是处于僵尸状态(注意:僵尸状态是一个问题),进程推出时没有立即回收它的退出代码。
3.僵尸状态的例子
创建一个子进程,让父进程不要退出,并且什么也不干(不回收子进程),让子进程退出(exit(0)
头文件是stdlib.h
),这时子进程就处于僵尸状态。
3.僵尸状态的危害
- 进程的退出状态必须被维持下去,因为他要告诉它的父进程(或者0S),你交给我的任务,我办的怎么样了(即,结果如何)。如果父进程一直不读取,子进程就会一直处于Z状态。
- 维持退出状态本身也是需要数据维护的,也属于进程的基本信息,因此它是保存在task_struct(PCB)中的。当然,如果Z状态一直不退出,该PCB就要一直被维护。
- 如果推广父进程创建了很多子进程,但是不回收,是不是就会造成内存资源的浪费(内存泄漏)?
数据结构对象本身就要占内存(C中定义一个结构体变量/对象,是需要在内存的某个位置开辟空间的)
5.孤儿进程
那么问题来了,如果父进程先退出,子进程再退出进入Z状态后,又该怎么办呢?
- 父进程先退出的话,它的子进程就被称为“孤儿进程”。
- 孤儿进程会被操作系统的1号init进程领养,它的资源由init进程回收。
三、进程的优先级
1.优先级概念
1.权限与优先级
权限是限制是否可以做某事,优先级是限制做某事的顺序(先做还是后做)。
2.什么是优先级
- 获得某个资源的顺序(是先获得该资源还是后获得该资源)。
- 优先级和进程的状态一样本质是是进程PCB中的一个(或几个)整型数字,Linux中的优先级是用两个整型数表示的。
3.为什么存在优先级
因为资源是有限的,但是有很多进程都想申请资源。
4.特性
- 竞争性:
系统的进程众多,但是CPU资源只有少量(甚至只有一个),所以进程之间是具有竞争属性的。为了高效完成任务,更加合理的竞争相关的资源,便具有了优先级。 - 独立性:
多进程运行需要独享各种资源,多进程运行期间互不干扰。 - 并行:
多个进程在多个CPU下,同时进行运行,这称之为并行。 - 并发:
多个进程在单个CPU下采用进程切换(CPU采用轮转的方式,给每个进程一定的时间片运行,进行进程切换)的方式,在一段时间内多个进程一同推进,称之为并发。
2.查看系统进程
在Linux/Unix系统中,用ps -la
命令可以查看进程的信息。
UID:该代表执行者的身份
PID:该进程的代号
PPID:该进程是由哪个进程发展衍生来的(即该进程的父进程的PID)
PRI:该进程可被执行的优先级
NI:该进程的nice值
3.PRI和NI
- PRI:进程的优先级,该值越小优先级越高;
- NI:进程的nice值,表示进程可以被执行的优先级的修正数值(调节进程优先级)
- PRI(new) = PRI(old)+ NI;
- 当nice值为负值时,该进程的优先级值会变小,优先级会变高,越快被执行;
- nice的取值范围为-20到19,总共40个级别。
4.修改进程的优先级
在Linux中修改进程的优先级是通过修改PRI和NI。也就是说,进程的优先级是受到nice值的影响的,但是默认情况下nice值为0.
新的优先级 = 老的优先级 + NI
注意:老的优先级指80(即,一旦要修改进程的优先级,无论它之前的优先级为多少都将老的优先级设置为80!),其中NI是nice值,他的取值范围为[-20,19],这意味着优先级是有取值范围的[80 - 20,80 + 19]。
修改进程的优先级,就是修改nice值。
命令是:
sudo top
- 步骤1:
sudo top
- 步骤2:进入top后,输入r然后输入进程的pid(进入该进程),输入要修改的nice值。
注意:调整进程的优先级不代表可以随意调整,这种做法是操作系统不允许的,会导致调度失衡,因此有一定的取值范围。
总结
以上就是今天要讲的内容,本文介绍了创建进程、查看进程、进程的状态以及进程的优先级相等关概念。本文作者目前也是正在学习C++相关的知识,如果文章中的内容有错误或者不严谨的部分,欢迎大家在评论区指出,也欢迎大家在评论区提问、交流。
最后,如果本篇文章对你有所启发的话,希望可以多多支持作者,谢谢大家!
相关文章:

Linux之创建进程、查看进程、进程的状态以及进程的优先级
文章目录 前言一、初识fork1.演示2.介绍3.将子进程与父进程执行的任务分离4.多进程并行 二、进程的状态1.进程的状态都有哪些?2.查看进程的状态2.运行(R)3.阻塞4.僵尸进程(Z)1.僵尸状态概念2.为什么要有僵尸状态&#…...

k8s部署rabbitmq
docker pull rabbitmq:3.9.28-management 1.部署模板 apiVersion: v1 kind: Service metadata:name: rabbitmq spec:ports:- name: amqpport: 5672targetPort: 5672- name: managementport: 15672targetPort: 15672selector:app: rabbitmq---apiVersion: apps/v1 kind: Statef…...

关于QGroundControl的软件架构的理解
首先QGC是基于QT平台开发,个人理解软件架构即为项目前后端结构,以及前后端数据交互的逻辑。下面是对QGroundControl源码的一些个人理解,写这个博客只是为了记录下来,防止时间久了忘记,过程中看了一些大佬的博客来帮助理…...
Android 文本识别:MLKIT + PreviewView
随着移动设备的普及和摄像头的高像素化,利用相机进行文本识别成为了一种流行的方式。MLKit 是 Google 提供的一款机器学习工具包,其中包含了丰富的图像和语言处理功能,包括文本识别。PreviewView 是 Android Jetpack 的一部分,它提…...

刮泥机的分类有哪些及组成部分
刮泥机的分类有哪些及组成部分 刮泥机的分类: 刮泥机主要包括:周边传动刮泥机、中心传动浓缩刮泥机。 1、中心传动浓缩刮泥机:主要由溢流装置、大梁及拦杆、进口管、传动装置、电器箱、稳流筒、主轴、浮渣耙板、刮集装置、水下轴承、小刮刀、…...

Qt编程基础 | 第六章-窗体 | 6.2、VS导入资源文件
一、VS导入资源文件 1.1、导入资源文件 步骤一: 将所有图片放到各自文件夹下,并将文件夹拷贝到资源文件(.qrc文件)的同级目录下,如下: 步骤二: 新建VS项目的时候,系统会自动建好一…...

NET框架程序设计-第4章类型基础
4.1 所有类型的基类型:System.Object CLR 要求每个类型最终都要继承自 System.Object 类型。 两种类型定义: 1)隐式继承 //隐式继承 Object class Employee{}2)显式继承 class Employee:System.Object{}System.Object 主要的公…...

Java设计模式-备忘录模式
简介 在软件开发中,设计模式是为了解决常见问题而提出的一种经过验证的解决方案。备忘录模式(Memento Pattern)是一种行为型设计模式,它允许我们在不破坏封装性的前提下,捕获和恢复对象的内部状态。 备忘录模式是一种…...

Zookeeper集群 + Kafka集群
Zookeeper 概述 Zookeeper 定义 Zookeeper是一个开源的分布式的,为分布式框架提供协调服务的Apache项目。 Zookeeper 工作机制 Zookeeper从设计模式角度来理解:是一个基于观察者模式设计的分布式服务管理框架,它负责存储和管理大家都关心的数…...

“邮件营销新趋势,这个平台让你收获颇丰!
随着各媒体平台的迅速发展,2023年大家更专注于视频营销、网红营销、直播营销等营销方式。可以见得,数字媒介手段的发展,对于营销方式也产生了巨大的影响。但是,企业在拥抱新兴的营销方式的同时,也不要忽视传统的营销方…...

Python列表推导
列表推导式 列表推导式创建列表的方式更简洁。常见的用法为,对序列或可迭代对象中的每个元素应用某种操作,用生成的结果创建新的列表;或用满足特定条件的元素创建子序列。 例如,创建平方值的列表: squares [] for …...

git使用查看分支、创建分支、合并分支
一、查看分支 查看的git命令如下: git branch 列出本地已经存在的分支,并且当前分支会用*标记 git branch -r 查看远程版本库的分支列表 git branch -a 查看所有分支列表(包括本地和远程,remotes/开头的表示远程分支)…...

vue3.0与vue2.0
一、生命周期的变化 1.vue2.响应式架构 2.vue3.0 响应式架构图 Vue3.0响应式框架在设计上,将视图渲染和数据响应式完全分离开来。将响应式核心方法effect从原有的Watcher中抽离。这样,当我们只需要监听数据响应某种逻辑回调(例如监听某个text属性的变化…...

HTML 中的常用标签用法
HTML是构建Web页面的基础语言,其中包含许多不同类型的标签。这些标签由尖括号包围,以指示浏览器如何呈现文本。下面是HTML中的一些常用标签以及它们的使用方法: 标题标签(h1-h6) 标题标签用于标识页面内容的标题&…...

【C++】指针 - 定义和使用,所占内存空间,空指针,野指针,const 修饰指针,指针和数组,指针和函数
文章目录 1. 定义和使用2. 所占内存空间3. 空指针4. 野指针5. const 修饰指针6. 指针和数组7. 指针和函数 1. 定义和使用 数据类型 * 变量名; 指针的作用是,可以通过指针间接访问内存。 内存编号是从 0 开始记录的,一般用十六进制数字表示。可以利用指…...

新规之下产业园区如何合理收费水电费用
一、政策背景 2018年3月30日,国家发改委发布《国家发展改革委关于降低一般工商业电价有关事项的通知》。明确提出进一步规范和降低电网环节收费,一是提高两部制电价的灵活性;二是全面清理规范电网企业在输配电价之外的收费项目,重…...

1011. 在 D 天内送达包裹的能力
传送带上的包裹必须在 days 天内从一个港口运送到另一个港口。 传送带上的第 i 个包裹的重量为 weights[i]。每一天,我们都会按给出重量(weights)的顺序往传送带上装载包裹。我们装载的重量不会超过船的最大运载重量。 返回能在 days 天内将…...

基于SpringBoot养老院管理系统
目录 一、项目介绍 二. 运行环境 三、项目技术 四、部署项目 五、项目运行 六、项目展示 五、项目下载 一、项目介绍 基于springboot的养老院管理系统拥有多种角色账号:管理员和用户 管理员:管理员管理、用户管理、健康管理、病例方案管理、药品…...

1.3 eBPF的工作原理初探
写在前面 上一节提到过,eBPF程序是面向BPF体系结构指令集编写的,它并不直接运行在Linux内核中,我们可以理解为它是运行在eBPF虚拟机,由eBPF虚拟机来执行eBPF字节码,就像java运行在jvm一样。 我们用一张原理图来看下eBPF程序的编译,加载,验证,钩子,映射等结点。 如上是…...

【CH32】| 02——常用外设 | GPIO
系列文章目录 【CH32】| 00——开发环境搭建 【CH32】| 01——新建工程 | 下载 | 运行 |调试 【CH32】| 02——常用外设 | GPIO 失败了也挺可爱,成功了就超帅。 文章目录 前言1. GPIO简介2. IO口的内部结构框图保护二极管上下拉电阻施密特触发器两个MOS管输出寄存器…...

第四章 测试用例编
本科程目标 1.什么是测试用例 2.测试用例的重要性 3.测试用例的八大要素(重点) 4.测试用例的评审 一、什么叫软件测试用例 测试用例(TestCase)是为项目需求而编制的一组测试输入、执行条件以及预期结果,以便测试…...

解决dpdk reserve的内存返回的虚拟地址和iova地址一样的问题
1. 背景: 在ubuntu20.04上用dpdk API: rte_memzone_reserve_aligned("L1L2_PCIE_MEMORY", 1.5*1024*1024*1024, rte_socket_id(), RTE_MEMZONE_1GB|RTE_MEMZONE_IOVA_CONTIG, RTE_CACHE_LINE_SIZE); 分配1.5…...

JQuery实现小项目
博主简介:想进大厂的打工人博主主页:xyk:所属专栏: JavaEE初阶 目录 文章目录 一、JQuery是什么 二、JQuery项目 2.1 猜数字 2.2 表白墙 2.3 聚合搜索 2.4 计算器 一、JQuery是什么 jQuery是一个快速、简洁的JavaScript框架,是继Prototype之…...

【C++/嵌入式笔试面试八股】一、23.结构体指针 | 指针和引用 | 万能指针 | 野指针
结构体指针 28.将结构体作为参数向函数中传递 传递方式有两种: 值传递地址传递,利用操作符 -> 可以通过结构体指针访问结构体属性//学生结构体定义 struct student {//成员列表string name; //姓名int age; //年龄int score; //分数 };//值传递...

【C++初阶】类和对象(下)构造函数(初始化列表) + explicit关键字 +static成员
👦个人主页:Weraphael ✍🏻作者简介:目前学习C和算法 ✈️专栏:C航路 🐋 希望大家多多支持,咱一起进步!😁 如果文章对你有帮助的话 欢迎 评论💬 点赞…...

chatgpt赋能python:Python代码怎么用?一个10年编程经验工程师的实践总结
Python代码怎么用?一个10年编程经验工程师的实践总结 如果你正在学习Python或已经是一名Python开发者,你需要知道如何正确地使用Python代码以实现项目需求。在本文中,我将分享我的10年Python编程经验,并介绍一些关于如何使用Pyth…...

【Android定制】修改BUILD_AGO_GMS = no 和 BUILD_GMS=no属性
文章目录 概要名词解释细节小结 概要 在安卓底层源码中,有这样的两个属性,这两个第一眼看上去都像是带不带谷歌,BUILD_AGO_GMS no和BUILD_GMSno有什么区别?? 如果带了谷歌,那么这个设备就差不多是国外定…...

第十章:C语言的调试
很多小伙伴刚开始听到C语言的调试,这是个啥,表示很怀疑,敲代码不就是直接就是干嘛,结果很多小白们,一运行错误多的数都数不过来。就开始这改改,那删删,莫名奇妙就运行成功了。到最后都不知道到底…...

【20】SCI易中期刊推荐——计算机信息系统工程电子与电气(中科院3区)
💖💖>>>加勒比海带,QQ2479200884<<<💖💖 🍀🍀>>>【YOLO魔法搭配&论文投稿咨询】<<<🍀🍀 ✨✨>>>学习交流 | 温澜潮生 | 合作共赢 | 共同进步<<<✨✨ 📚📚>>>人工智能 | 计算机视觉…...

初识网络之UDP网络套接字
目录 一、UDP中的socket编程常用接口 1. socket的含义 2. sockaddr结构 3. socket编程中UDP协议常用接口介绍 3.1 创建socket文件描述符(TCP/UDP、客户端 服务器) 3.2 绑定端口号(TCP/UDP,服务器) 3.3 接收数据…...