Linux——进程|描述进程-PCBtask_struct-PCB的一种组织进程 |查看进程父进程和子进程|PID获取|父子关系|fork初识

简介: 笔记

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

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

进程:对应的代码和数据+PCB结构体

描述进程-PCB


进程信息被放在一个叫做进程控制块的数据结构中,可以理解为进程属性的集合。

课本上称之为PCB(process control block), Linux操作系统下的PCB是: task_struct


cpu不能直接去访问文件中的程序和数据,而是通过访问PCB,才能访问数据和程序


cpu对进程的管理,变成了对进程PCB结构体链表的增删查改


task_struct-PCB的一种

在Linux中描述进程的结构体叫做task_struct。

task_struct是Linux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息


task_ struct内容分类

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

状态: 任务状态,退出代码,退出信号等。

优先级: 相对于其他进程的优先级。

程序计数器: 程序中即将被执行的下一条指令的地址。

内存指针: 包括程序代码和进程相关数据的指针,还有和其他进程共享的内存块的指针

上下文数据: 进程执行时处理器的寄存器中的数据[休学例子,要加图CPU,寄存器]。

I/ O状态信息: 包括显示的I/O请求,分配给进程的I/ O设备和被进程使用的文件列表。

记账信息: 可能包括处理器时间总和,使用的时钟数总和,时间限制,记账号等。

其他信息


组织进程

管理理念:先描述,再组织


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


查看进程


我们执行一个程序就是开始一个进程,程序结束,进程结束



我们改成死循环代码



查看进程输入ps,ps只能查看自己的终端下的进程,若想查看所有进程输入ps axj



输入ps axj,此时查看的是系统中所有进程的信息


1.png


还可利用ps axj查看自己的


ps axj | grep 'mypro'


2.png


带上头部 ps axj | head -1 && ps axj |grep 'mypro'

3.png



输入top命令,也可显示系统中的所有进程,相当于任务管理器,退出q



4.png5.png

系统中还有一个proc的目录


6.png


我们可以看到当前进程的PID是21682

7.png



我们在proc 里面可以找到这个数字ls /proc -l


8.png


我们可以利用它的pid查看进程,我们所看到的是它进程的所有属性数据9.png




我们可以看到当前工作目录和可执行程序


cwd是当前进程的工作目录,exe可执行程序


C语言代码->可执行程序->运行可执行程序->每个进程都会有一个属性,来保存自己所在的工作路径(进程运行时所在的工作路径)


进程的当前路径在跟可执行程序在一个路径

10.png



也可这样查看属性

11.png

当我们退出程序时,再去查看这个路径,发现已经没有这个路径了

12.png


因此/proc里面的文件是动态变化的


父进程和子进程


PID获取

输入man getpid可查看pid


这里面看到的头文件和C语言没有任何关系,这是操作系统提供的头文件


pid_t是操作系统提供的一个pid类型,其实是unsigned int


所有函数在变成进程之后才能被调用


13.png14.png



运行

15.png16.png


输入kill -9 30254可以终止程序进行,终止进程


17.png

父子关系

man getppid获得父进程ID,get pid获得进程ID


18.png



这里的父进程ppid是谁?



我们可以看到ppid就是bash,bash是一种shell的一种


无论是系统的命令还是自己编写的程序,都是bash(shell)的子进程


我们关掉bash





输什么命令都不起作用


我们重新登陆即可,但是每次登陆的时候,PPID都不同,每次登陆都是打开bash




fork初识


fork:用来创建一个子进程


返回值:1.失败的时候返回-1


               2.成功的时候子进程pid返回给父进程,0返回给子进程



一个程序没有fork时



我们加上fork



再次修改


20.png21.png22.png



从fork之后变成了俩个进程,一个是父进程,一个是子进程


23.png


 i am parent ....打印的是子进程

24.png



fork之后产生了俩个进程,一个是上面的ret,一个是下面的ret,因为给子进程返回0,给父进程返回子进程的pid,所以上面是父进程,下面是子进程,


子进程的ppid是14672,14672就是父进程的pid


fork子进程探讨

25.png

运行之后程序打印了俩次

26.png



执行俩遍是因为创建了子进程,在fork之后代码是父子共享的

27.png



再次修改程序

28.png



运行之后,由于fork成功子进程返回的是0,子进程进入else if,父进程返回的是子进程的PID,父进程进入else,这里的if和else if同时执行,这是因为fork之后有俩个不同的进程流

29.png

一个子进程只能有一个父进程,一个父进程可以有多个子进程,所以是父子关系


输入这个语句可动态观察: while :; do ps axj | head -1 && ps ajx | grep mypro | grep -v grep;sleep 1;done

30.png



fork俩个返回值问题

fork会创建一个子进程,会把0或-1返回给子进程,把子进程PID返回给父进程,为什么会有俩个返回值呢?


创建子进程的时候,要新建一个task_struct结构体,子进程的内部属性要以父进程为模板,就像父子DNA关系一样


31.png


当准备return时,我们的核心代码已经完成了吗?


32.png


通过task_struct将代码加载到寄存器当中


操作系统和cpu运行某一个进程,本质从task_struct形成的队列中挑选一个task_struct,来执行它的代码,进程调度,变成了在task_struct的队列中选择一个进程的过程


只要想到进程,优先想到对应的task_struct


当我们准备return的时候,核心代码已经完成了,当子进程准备return的时候,子进程已经被创建出来了,甚至放在了运行队列当中


当父进程被cpu调度的时候,会return 一个值给父进程,子进程被调度的时候,会return一个值给子进程,所以会出现return俩次的情况


总结:


1.因为fork内部,父子各自会执行自己的return语句


2.返回俩次,并不意味着会保存俩次


父子进程被创建出来,哪一个先运行?


这个没有固定答案,有可能是父进程,也有可能是子进程,因此谁先运行不一定,这个由操作系统的调度器决定


相关文章
|
13天前
|
缓存 监控 Linux
linux进程管理万字详解!!!
本文档介绍了Linux系统中进程管理、系统负载监控、内存监控和磁盘监控的基本概念和常用命令。主要内容包括: 1. **进程管理**: - **进程介绍**:程序与进程的关系、进程的生命周期、查看进程号和父进程号的方法。 - **进程监控命令**:`ps`、`pstree`、`pidof`、`top`、`htop`、`lsof`等命令的使用方法和案例。 - **进程管理命令**:控制信号、`kill`、`pkill`、`killall`、前台和后台运行、`screen`、`nohup`等命令的使用方法和案例。
44 4
linux进程管理万字详解!!!
|
4天前
|
存储 运维 监控
深入Linux基础:文件系统与进程管理详解
深入Linux基础:文件系统与进程管理详解
41 8
|
13天前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
46 4
|
14天前
|
缓存 负载均衡 算法
Linux内核中的进程调度算法解析####
本文深入探讨了Linux操作系统核心组件之一——进程调度器,着重分析了其采用的CFS(完全公平调度器)算法。不同于传统摘要对研究背景、方法、结果和结论的概述,本文摘要将直接揭示CFS算法的核心优势及其在现代多核处理器环境下如何实现高效、公平的资源分配,同时简要提及该算法如何优化系统响应时间和吞吐量,为读者快速构建对Linux进程调度机制的认知框架。 ####
|
15天前
|
消息中间件 存储 Linux
|
22天前
|
运维 Linux
Linux查找占用的端口,并杀死进程的简单方法
通过上述步骤和命令,您能够迅速识别并根据实际情况管理Linux系统中占用特定端口的进程。为了获得更全面的服务器管理技巧和解决方案,提供了丰富的资源和专业服务,是您提升运维技能的理想选择。
23 1
|
1月前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
【10月更文挑战第9天】本文将深入浅出地介绍Linux系统中的进程管理机制,包括进程的概念、状态、调度以及如何在Linux环境下进行进程控制。我们将通过直观的语言和生动的比喻,让读者轻松掌握这一核心概念。文章不仅适合初学者构建基础,也能帮助有经验的用户加深对进程管理的理解。
21 1
|
1月前
|
消息中间件 Linux API
Linux c/c++之IPC进程间通信
这篇文章详细介绍了Linux下C/C++进程间通信(IPC)的三种主要技术:共享内存、消息队列和信号量,包括它们的编程模型、API函数原型、优势与缺点,并通过示例代码展示了它们的创建、使用和管理方法。
30 0
Linux c/c++之IPC进程间通信
|
1月前
|
Linux C++
Linux c/c++进程间通信(1)
这篇文章介绍了Linux下C/C++进程间通信的几种方式,包括普通文件、文件映射虚拟内存、管道通信(FIFO),并提供了示例代码和标准输入输出设备的应用。
26 0
Linux c/c++进程间通信(1)
|
1月前
|
Linux C++
Linux c/c++进程之僵尸进程和守护进程
这篇文章介绍了Linux系统中僵尸进程和守护进程的概念、产生原因、解决方法以及如何创建守护进程。
20 0