《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://xiahunao.cn/news/1381986.html

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

相关文章

RT-Thread智能音箱音频应用实践

国内智能音箱的问世早于国外&#xff0c;但由于国内对智能化概念普及程度较低&#xff0c;初期智能音箱并没有受到很多关注。但近几年国内智能音箱行业经历了从百花齐放到三足鼎立的发展阶段&#xff0c;来自RT-Thread的黄天翔将从占据主流市场的三个厂商脱颖而出的秘诀开始&am…

智能音箱技术概览

目前的智能音箱多基于语音控制&#xff0c;其基本交互流程可以用图1 概括&#xff1a; 1&#xff09;用户通过自然语言向音箱提出服务请求或问题 2&#xff09;音箱拾取用户声音&#xff08;音箱本地完成&#xff09;并分析&#xff08;一般在服务器端完成&#xff09; 3&#…

揭秘智能音箱里那些神秘的声学技术

音箱行业有着悠久的历史&#xff0c;但是在过去十多年里&#xff0c;传统的音箱行业面临着极大的市场困境&#xff0c;例如蓝牙音箱刚出现各个厂商便直接杀成了一片红海。而2015年随着智能音箱的涌现&#xff0c;特别是亚马逊的Echo、京东的叮咚、阿里的小飞&#xff0c;不仅对…

智能家居控制系统MECOOL KA1智能音响

MECOOL KA1是智能音箱和4K安卓电视流媒体设备的结合。该设备采用Amlogic S905Y4 SoC四核ARM Cortex -A35处理器&#xff0c;支持远场语音和免提电视控制。 MECOOL KA1通过ART&#xff08;谷歌智能语音测试&#xff09; ART 旨在验证集成了 Google 助理的设备的助理功能。要被…

AI智能音箱五大功能中应用的数字功放芯片

AI智能音箱多基于语音控制&#xff0c;其基本交互流程可以用下图概括&#xff1a;1&#xff09;用户通过自然语言向音箱提出服务请求或问题 2&#xff09;音箱拾取用户声音&#xff08;音箱本地完成&#xff09;并分析&#xff08;一般在服务器端完成&#xff09;3&#xff09;…

Talk | ICCV‘23清华大学刘世隆:From Detection to Grounding-迈向更强的开集目标检测

本期为TechBeat人工智能社区第521期线上Talk&#xff01; 北京时间8月10日(周四)20:00&#xff0c;清华大学博士生—刘世隆的Talk已准时在TechBeat人工智能社区开播&#xff01; 他与大家分享的主题是: “From Detection to Grounding-迈向更强的开集目标检测”&#xff0c;他分…

5个PPT素材、模板网站,建议收藏~

做PPT绝对不能错过这5个网站&#xff0c;建议收藏~ 1、菜鸟图库 https://www.sucai999.com/search/ppt/0_0_0_1.html?vNTYxMjky 菜鸟图库素材非常齐全&#xff0c;设计、办公、图片、视频等素材这里都能找到&#xff0c;PPT模板数量很可观&#xff0c;模板样式多&#xff0c…

数据结构和算法——散列表的性能分析(开放地址法的查找性能、期望探测次数与装填因子的关系、分离链接法的查找性能)

目录 开放地址法的查找性能 线性探测法 平方探测法和双散列探测法 期望探测次数与装填因子的关系 分离链接法的查找性能 总结 散列表的性能分析 平均查找长度&#xff08;ASL&#xff09;用来度量散列表查找效率&#xff1a;成功、不成功关键词的比较次数&#xff0c;取…

Dataloader数据集的制作

数据集Dataloader制作 如何自定义数据集&#xff1a; 1.数据和标签的目录结构先搞定(得知道到哪读数据)2.写好读取数据和标签路径的函数(根据自己数据集情况来写)3.完成单个数据与标签读取函数(给dataloader举一个例子) 咱们以花朵数据集为例&#xff1a; 原来数据集都是以…

RabbitMQ 消息队列(Spring boot AMQP)

文章目录 &#x1f370;有几个原因可以解释为什么要选择 RabbitMQ&#xff1a;&#x1f969;mq之间的对比&#x1f33d;RabbitMQ vs Apache Kafka&#x1f33d;RabbitMQ vs ActiveMQ&#x1f33d;RabbitMQ vs RocketMQ&#x1f33d;RabbitMQ vs Redis &#x1f969;linux docke…

Android App消息推送 实现原理

https://www.jianshu.com/p/b61a49e0279f 1.消息推送的实质 实际上&#xff0c;是当服务器有新消息需推送给用户时&#xff0c;先发送给应用App&#xff0c;应用App再发送给用户 2. 作用产品角度&#xff1a;功能需要&#xff0c;如&#xff1a;资讯类产品的新闻推送、工具类…

App消息推送 实现原理

1.消息推送的实质 实际上&#xff0c;是当服务器有新消息需推送给用户时&#xff0c;先发送给应用App&#xff0c;应用App再发送给用户 2. 作用 产品角度&#xff1a;功能需要&#xff0c;如&#xff1a;资讯类产品的新闻推送、工具类产品的公告推送等等 运营角度&#xff1a;活…

浏览器及app消息推送

消息推送 什么是消息推送PC端的实现方法1:Notification方法2&#xff1a;pushjs APP端实现打包设置 什么是消息推送 消息推送可以存在于浏览器端&#xff0c;也存在APP端。浏览器的推送&#xff0c;会在电脑通知中显示&#xff0c;app中显示在通知栏 PC端的实现 方法1:Notif…

IOS推送-pushy

iOS 引入jar包创建APNSConnect进行发送报错对照表 引入jar包 创建APNSConnect 创建APNSConnect&#xff0c;与APNs进行链接 public class APNSConnect { private static ApnsClient apnsClient null;public static ApnsClient getAPNSConnectP8(String path,String teamId,S…

unipush+java+个推实现app消息推送

“ 你现在的气质里&#xff0c;藏着你走过的路&#xff0c;读过的书&#xff0c;和爱过的人。 ” 整体还是比较简单地&#xff0c;就是有一些需要注意的地方&#xff0c;很多问题官方文档里面也写了&#xff0c;这里总结一下 对于安卓&#xff0c;谷歌本来有专门的推送通道&…

uniapp - App 超详细消息推送功能实现,从 0-1 实现官方 unipush 推送全步骤稳定性毋庸置疑(附带详细的可运行示例源码和注释,保证 100% 完美接入)苹果安卓手机

效果图 网上的教程太乱用不了,无法改造成自己想要的效果。 在uniapp中开发的app(安卓苹果),使用 unipush 官方推送,从0-1实现完整过程及功能开发。 你可以直接复制示例源码,跟着教程一步步配置,注释详细! 准备 消息

Android 项目必备(三十八)-->APP 消息推送

文章目录 前言推送的实现方式1. C2DM2. 轮询3. SMS信令推送4. MQTT协议5. XMPP协议6. 使用第三方平台 Android 中 MQTT 的使用1. 集成2. 具体代码3. 项目地址 前言 今天来讲讲推送这件小事&#xff0c;事虽小&#xff0c;要做好却不容易。 推送难&#xff0c;难于上青天。 我们…

APP消息推送(APP Push)解决方案-服务端工作逻辑和实现

一、APP 推送概述&#xff1a; App推送消息是我们常见的一种app消息提醒方式。 我们的实现需要第三方的支持&#xff0c;实现方式是后台通过接口将Push请求发送至第三方&#xff0c;第三方实现在App所在设备上的推送。 二、APP推送后台处理逻辑&#xff1a; 在与推送平台交互时…

app消息推送的详细实现教程

实现的主要思想 app实现消息推送&#xff0c;利用的是第三方的个推平台&#xff0c;后端将需要推送的内容通过第三方个推服务器传递给手机端。 具体前端打包配置 根据上图可知&#xff0c;采用的打包软件是Hbuilder X,在模块配置的时候&#xff0c;勾选push模块中的uniPush。…

App消息推送的原理

文章目录 1. 基本概念2. iOS和Android消息推送原理对比2.1 iOS2.1.1 基本原理2.1.2 优劣势 2.2 Android2.2.1 基本原理2.2.2 优劣势 3. Android消息推送原理3.1 操作系统有自身的消息推送功能&#xff08;系统级别&#xff09;3.2 三种基本的推送方式&#xff1a;Push、Pull 和…