《Linux从练气到飞升》No.12 Linux进程概念

🕺作者: 主页

我的专栏
C语言从0到1
探秘C++
数据结构从0到1
探秘Linux
菜鸟刷题集

😘欢迎关注:👍点赞🙌收藏✍️留言

🏇码字不易,你的👍点赞🙌收藏❤️关注对我真的很重要,有问题可在评论区提出,感谢阅读!!!

文章目录

    • 前言
    • 进程基本概念
    • 描述进程-PCB
      • task_struct-PCB的一种
      • task_ struct内容分类
    • 组织进程
    • 查看进程
    • 通过系统调用获取进程标示符
    • 通过系统调用创建进程-fork初识
      • 1. 父子进程代码共享,数据各自开辟空间,私有一份(采用写时拷贝)。
      • 2. 父进程先运行还是子进程先运行?
      • 3. 创建子进程时OS要做什么?
    • 后记

前言

本篇我们将正式进入Linux的世界,首先先要讲的就是进程,进程是什么?怎么描述?如何组织、查看?如何创建?本篇都将详细讲解~

进程基本概念

  • 课本概念:程序的一个执行实例,正在执行的程序等

实际上,我们启动一个软件的本质上就是启动了一个进程,在Linux系统中运行 ./a.out 时,其实就是在系统的层面上创建了一个进程,如下:

#include <stdio.h>    
#include <unistd.h>    
int main() {   while(1)   {   printf("hello world!\n");   sleep(1);   }   return 0;   
} 

在这里插入图片描述

  • 内核观点:担当分配系统资源(CPU时间,内存)的实体。

从内核观点看的话,就是如下图这样,后面再讲概念。
在这里插入图片描述

按照之前操作系统篇讲过的先描述再组织,所以可以预言系统中会存在一个管理对应进程的结构体,因为不同的进程的属性不同,不可能直接管理进程,只能通过一个结构体来管理它,这个结构体的内容应该包括该进程的各个属性,我们之后叫它PCB(process control block),当然不同的系统中的叫法可能不同,但是理念是一样的。

区分程序和进程

  1. 程序的本质是一个静态文件,存储在磁盘中

  2. 进程是对应的代码+数据+进程对应的PCB结构体

描述进程-PCB

进程信息被放在一个叫做进程控制块的数据结构中,可以理解为进程属性的集合。
课本上称之为PCB(process control block)Linux操作系统下的PCB是: task_struct
在这里插入图片描述

task_struct-PCB的一种

在Linux中描述进程的结构体叫做task_struct
task_struct是Linux内核的一种数据结构(双向链表),它会被装载到RAM(内存)里并且包含着进程的信息。

task_ struct内容分类

    1. 进程标示符: 描述本进程的唯一标示符,用来区别其他进程。

进程PID在当前操作系统中唯一标识一个进程的标识符。

ps aux命令可以查看当前操作系统中所有的进程信息
在这里插入图片描述

    1. 进程状态: 任务状态,退出代码,退出信号等。
      进程状态:
      三种状态:
      运行态:正在拿着CPU资源进行运算的进程所持有的状态
      就绪态:一切的准备资源都准备就绪了,等待操作系统分配CPU资源
      阻塞态:等待某种资源到来之后才能进行运算
      细分状态:
      R:运行状态
      S:可中断睡眠状态:意味着进程在等待事件完成
      在这里插入图片描述

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

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

      t:跟踪状态,当进程被gdb调试时会产生t
      X:死亡状态:这个状态只是一个返回状态,你不会在任务列表里看到这个状态
      Z:僵尸状态:一个比较特殊的状态。当进程退出并且父进程没有读取到子进程退出的返回代码时就
      会产生僵死(尸)进程

    1. 进程优先级: 相对于其他进程的优先级。
    1. 程序计数器: 程序中即将被执行的下一条指令的地址。
      在这里插入图片描述
    1. 内存指针: 包括程序代码和进程相关数据的指针,还有和其他进程共享的内存块的指针
      在这里插入图片描述
    1. 上下文数据: 进程执行时处理器的寄存器中的数据。
      在这里插入图片描述
    1. I/O状态信息: 包括显示的I/O请求,分配给进程的I/O设备和被进程使用的文件列表。
    1. 记账信息: 可能包括处理器时间总和,使用的时钟数总和、时间限制、记账号、cpu使用率、内存使用率、CPU使用时长。
    1. 其他信息

组织进程

可以在内核源代码里找到它。所有运行在系统里的进程都以task_struct链表的形式存在内核里。

查看进程

进程的信息可以通过 /proc 系统文件夹查看
在这里插入图片描述

如:要获取PID为1的进程信息,你需要查看 /proc/1 这个文件夹。
在这里插入图片描述

大多数进程信息同样可以使用top和ps这些用户级工具来获取

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main() {while(1){  printf("hello world!\n");sleep(1);}  return 0; 
}
ps aux | grep mycode | grep -v grep

在这里插入图片描述

通过系统调用获取进程标示符

  • 进程id(PID)
  • 父进程id(PPID)
    返回0为子进程,返回大于0(子进程PID)为父进程,返回小于0,创建失败
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{printf("pid: %d\n", getpid());printf("ppid: %d\n", getppid());return 0;
}

在这里插入图片描述

通过系统调用创建进程-fork初识

1. 父子进程代码共享,数据各自开辟空间,私有一份(采用写时拷贝)。

  • 代码是逻辑,一般不可被修改,数据,即可读又可写。

  • 进程是有独立性的,父子进程fork完毕后,谁先运行是不确定的,这个有调度器决定。

测试代码:

#include <stdio.h>
#include <sys/types.h>
int main(int argc, char *argv[]) {printf("begin fork...\n");fork();printf("end fork...\n");return 0; 
}

结果:出现两个end fork…
在这里插入图片描述
测试代码

#include <stdio.h>
#include <sys/types.h>
int main(int argc, char *argv[]) {printf("create process failed\n");pid_t pid=fork();if(pid<0){printf("create process failed\n");}else if(pid == 0){ printf("create child success\n");}else{ printf("create parent success\n");}printf("end fork...\n");return 0;
}

结果:
在这里插入图片描述
在这里插入图片描述
pid进入两个分支说明了有两个pid值,也就说明fork有两个返回值,

为什么会有两个返回值?

  1. 因为fork内部,父子各自会执行自己的return语句
  2. 返回两次,并不意味着缓存两次。(以后讲)

return后核心代码都执行完了吗?

完成了

fork函数是怎么新建进程的?

操作系统和CPU运行某个进程,本质就是从task_struct链表中挑一个task_struct来执行它的代码,只要想到进程就要优先想到对应的task_struct,而进程调度就变成了在task_struct链表中选择一个进程的过程,fork函数就是再创建一个进程和task_struct,并将这个task_struct添加到task_struct队列中。
在这里插入图片描述

为什么给子进程返回0,父进程返回子进程的pid?(感性分析一下,并不完全正确)

子进程只有一个父进程,而父进程可以有多个子进程,fork之后,给父进程返回子进程的pid可以方便父进程对子进程进行管理,而父进程对子进程是唯一的,子进程只需要知道自己是否创建成功,成功创建后的父进程是谁即可。

既然子进程有父进程,那最终的父进程是谁?

是bash,bash是所有进程的父进程,验证如下: 子进程的ppid是父进程的pid,而父进程的ppid是bash,所以bash是所有进程的父进程。
代码:

#include<stdio.h>#include<unistd.h>int main(){  int ret=fork();if(ret<0){  printf("fork error!\n");}  else if(ret==0){  printf("i am child:%d ret=%d\n",getpid(),ret);}  else{  printf("i am parent:%d ret=%d\n",getppid(),ret);}  return 0; }  

运行结果:
在这里插入图片描述
查看:

ps aux | grep 32158

在这里插入图片描述

2. 父进程先运行还是子进程先运行?

  • 子进程在被创建后,在内核中会生成一个PCB对它进行管理,这个PCB会被挂在PCB构成的双向链表当中组织起来
  • 而父进程与子进程谁先运行是不确定的,取决于操作系统的调度
  • 它是抢占式执行的,也就是OS会给进程运行一段时间然后中止,把CPU资源让给其他进程。
  • 子进程在创建出来以后,子进程的运行与父进程无关了

3. 创建子进程时OS要做什么?

本质上就是新建了一个task_struct加入到系统中

在这里插入图片描述

后记

本篇主要讲述了进程的基本概念以及如何描述进程——PCB,并且讲述了如何通过系统调用获取进程标识符,如何创建子进程——初识fork,更为深入的讲解将在后面的文章进行讲述~

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

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

相关文章

算法与数据结构(二十二)动态规划解题套路框架

动态规划解题套路框架 此文只在个人总结 labuladong 动态规划框架&#xff0c;仅限于学习交流&#xff0c;版权归原作者所有&#xff1b; 动态规划问题&#xff08;Dynamic Programming&#xff09;应该是很多读者头疼的&#xff0c;不过这类问题也是最具有技巧性&#xff0c…

Arcgis将一个shp依照属性表导出为多个shp

# -*- coding:utf-8 -*-import arcpy import osfrom arcpy import env#env.workspace "./" #自己设置路径shp rC:\Users\Administrator\Desktop\Lake\xxx.shp #shp文件路径outpath r"C:\Users\Administrator\Desktop\Lake\fenli" #输出结果路径with arc…

使用Python和wxPython将图片转换为草图

导语: 将照片转换为艺术风格的草图是一种有趣的方式&#xff0c;可以为您的图像添加独特的效果。在本文中&#xff0c;我们将介绍如何使用Python编程语言和wxPython图形用户界面库来实现这一目标。我们将探讨如何使用OpenCV库将图像转换为草图&#xff0c;并使用wxPython创建一…

在线高精地图生成算法调研

1.HDMapNet 整体的网络架构如图所示&#xff0c;最终的Decoder输出三个分支&#xff0c;一个语义分割&#xff0c;一个embedding嵌入分支&#xff0c;一个方向预测。然后通过后处理将这些信息处理成向量化的道路表示。 img2bev的方式之前有IPM&#xff0c;通过假设地面的高度都…

面试热题(三数之和)

给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意&#xff1a;答案中不可以包含重复的三元组。 输入&…

[保研/考研机试] KY35 最简真分数 北京大学复试上机题 C++实现

题目链接&#xff1a; 最简真分数https://www.nowcoder.com/share/jump/437195121691719749588 描述 给出n个正整数&#xff0c;任取两个数分别作为分子和分母组成最简真分数&#xff0c;编程求共有几个这样的组合。 输入描述&#xff1a; 每组包含n&#xff08;n<600&…

微信小程序实现当前页面更新上一个页面

日常项目中需要实现的一个价格脱敏功能&#xff1a;通过点击页面二中的查看完整信息 点击回退按钮实现页面一中的价格显露出来 通过查询了大量资料发现 大多数都是通过调用上一个接口的onload 或者onshow 实现视图更新 经测试后 发现 无法实现 只能更改数据 无法更新视图 实现…

算能BM1684X部署手写数字识别模型

大致流程--------------------------------------------------------------- 参考《sophon-sail_zh》 移植步骤------------------------------------------------------------------------ 首先搭建好自己的网络模型&#xff0c;并导出为onnx格式--具体可以参照--> GitH…

大语言模型之一 Attention is all you need ---Transformer

大语言模型已经在很多领域大显身手&#xff0c;其应用包括只能写作、音乐创作、知识问答、聊天、客服、广告文案、论文、新闻、小说创作、润色、会议/文章摘要等等领域。在商业上模型即产品、服务即产品、插件即产品&#xff0c;任何形态的用户可触及的都可以是产品&#xff0c…

opencv基础46-图像金字塔02-拉普拉斯金字塔

前面我们介绍了高斯金字塔&#xff0c;高斯金字塔是通过对一幅图像一系列的向下采样所产生的。有时&#xff0c;我们希望通过对金字塔中的小图像进行向上采样以获取完整的大尺寸高分辨率图像&#xff0c;这时就需要用到拉普拉斯金字塔 前面我们已经介绍过&#xff0c;一幅图像在…

.Net C# 免费PDF合成软件

最近用到pdf合成&#xff0c;发现各种软件均收费啊&#xff0c;这个技术非常简单&#xff0c;别人写好的库一大把&#xff0c;这里用到了PDFsharp&#xff0c;项目地址Home of PDFsharp and MigraDoc Foundation 软件下载地址 https://download.csdn.net/download/g313105910…

网站SSL安全证书是什么及其重要性

网站SSL安全证书具体来说是一个数字文件&#xff0c;是由受信任的数字证书颁发机构&#xff08;CA机构&#xff09;进行审核颁发的&#xff0c;其中包含CA发布的信息&#xff0c;该信息表明该网站已使用加密连接进行了安全保护。 网站SSL安全证书也被称为SSL证书、https证书和…

Similarities:精准相似度计算与语义匹配搜索工具包,多维度实现多种算法,覆盖文本、图像等领域,支持文搜、图搜文、图搜图匹配搜索

Similarities&#xff1a;精准相似度计算与语义匹配搜索工具包&#xff0c;多维度实现多种算法&#xff0c;覆盖文本、图像等领域&#xff0c;支持文搜、图搜文、图搜图匹配搜索 Similarities 相似度计算、语义匹配搜索工具包&#xff0c;实现了多种相似度计算、匹配搜索算法&…

IDEA之Debug调试

资料来源于韩老师视频 &#xff08;一&#xff09;初探debug 1、打断点的话&#xff1a;直接在该行前面单击左键&#xff0c;出现小红点就是断点了。 想要取消断点的话&#xff0c;再单击小红点即可。 运行debug时&#xff0c;右键选择"Debug…"而不是选“Run…”…

【C++】开源:spdlog跨平台日志库配置使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍spdlog日志库配置使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下…

​LeetCode解法汇总1572. 矩阵对角线元素的和

目录链接&#xff1a; 力扣编程题-解法汇总_分享记录-CSDN博客 GitHub同步刷题项目&#xff1a; https://github.com/September26/java-algorithms 原题链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 描述&#xff1a; 给你一个正…

配置vscode

配置vscode 设置相关 网址&#xff1a;https://code.visualstudio.com/ 搜索不要用百度用这个&#xff1a;cn.bing.com 1.安装中文包 Chinese (Simplified) (简体中文) 2.安装 open in browser 3.安装主题 Atom One Dark Theme 4. 安装图标样式 VSCode Great Icons 5.安装 L…

yum 安装本地包 rpm

有时直接yum install 有几个包死活下不下来 根据网址&#xff0c;手动下载&#xff0c;下载后上传至 centos 然后运行 sudo yum localinstall xxx.rpm 即可安装 参考 https://blog.csdn.net/weiguang1017/article/details/52293244

MachineLearningWu_16/P72-P77_Diagnostic

x.1 导数&#xff0c;计算图&#xff0c;大型网络 计算图就是根据链式法则求取偏导&#xff0c;大型网络就是多层网络堆叠而成。 x.2 Diagnostic 在我们对深度学习有了一些认知后&#xff0c;最重要的就是模型的诊断&#xff0c;以带有L1正则化的线性回归为例&#xff0c;我…

SQL | 排序检索的数据

3-排序检索的数据 使用order by语句排序检索到的数据。 3.1-排序数据 使用SQL语句返回一个数据表的列。 select prod_id from products; --------------------- | prod_name | --------------------- | 8 inch teddy bear | | 12 inch teddy bear | | 18 inch teddy bear |…