嵌入式学习——Linux高级编程复习(进程)——day39

news/2024/9/24 21:25:27/

1. 进程

        进程是计算机科学中的一个核心概念,它是操作系统进行资源分配和调度的基本单位,代表了一个正在执行中的程序实例。当一个程序被加载到内存并开始执行时,它就变成了一个进程

        1. 程序:存放在外存中的一段代码的集合

        2. 进程:是一个程序动态执行的过程,包括创建、调度和消亡

        注意:

                进程间的通信方式

                1. 管道

                2. 信号

                3. 消息队列

                4. 共享内存

                5. 信号灯

                6. 套接字

2. 进程的创建(创建了一片虚拟内存空间、多个进程共用同一片虚拟内存空间,进程空间在实际的物理地址是独立的)

2.1 进程被执行后,操作系统开辟进程空间,并分为如下区域

        1. 文本段

        2. 数据段

        3. 系统数据段——堆区、栈区

        4. 内核(PCB(进程控制块)存在于操作系统内核中。它是内核用来管理和控制进程的关键数据结构)

补充:PCB块概念

        进程控制块(PCB,Process Control Block)是操作系统中用于描述和控制进程状态和属性的一个重要数据结构。每个活动的进程在操作系统中都有一个对应的PCB,它是进程存在的唯一标识。PCB包含了操作系统管理和调度进程所需的所有关键信息,其具体内容可能因操作系统的设计而异,但通常包括以下基本信息:

  1. 进程标识符(PID):唯一标识每个进程的编号。
  2. 进程状态:当前进程的状态,如就绪、运行、阻塞等
  3. 程序计数器(PC):保存进程下一条将要执行的指令的地址。
  4. 处理器状态寄存器:包括通用寄存器、指令寄存器等,用于保存进程执行时的上下文信息。
  5. 内存管理信息:如基址、界限寄存器值、页表指针等,用于内存访问和管理。
  6. 文件描述符表或打开文件列表:记录了进程当前打开的文件及其状态。
  7. 进程优先级:决定进程调度的优先级。
  8. CPU调度信息:如进程的调度队列指针、时间片剩余量等。
  9. 记账信息:如进程创建时间、CPU使用时间等统计信息。
  10. I/O状态信息:包括I/O请求队列、已完成和待处理的I/O操作等。
  11. 信号处理信息:与进程相关的信号处理规则和屏蔽位。

2.2 内存映射

        1. 进程空间是独立的(物理地址), 进程是操作系统资源分配的最小单元

        2. 所有进程所使用的虚拟地址空间都为同一空间(虚拟地址)

        3. 每个进程运行起来后,操作系统都会分配一个内存空间(虚拟地址)

3. 进程调度

3.1 运行方式

        宏观并行,微观串行

        1.宏观:大角度 用户 
        2.微观:小角度 CPU 

3.2 进程状态(进程在调度过程中频繁保存现场恢复现场,使得进程拥有了一些不同的状态)

    1.就绪态、运行态    R
    2.可唤醒等待态        S(sleep、scanf)        睡眠态
    3.不可唤醒等待态     D(加载驱动)        
    4.暂停态                    T                
    5.僵尸态                    Z(代码运行完了,空间还在,需要回收空间)        
    6.结束态                    X(空间被回收的一瞬间)

3.3 进程调度算法(完成从一个进程切换到下一个进程去执行相应的任务)

        1.先来先执行,后来后执行
        2.高优先级调度算法
        3.时间片轮转调度算法:CPU在一个任务中执行的一小段时间成为一个时间片
        4.多级队列反馈调度算法
        5.负载均衡调度算法

4. 进程相关命令

4.1 top

        根据CPU占用率查看进程信息、PID:进程ID号、PPID:父进程ID号 、q退出

4.2 ps -ef

        查看所有进程信息(当前时刻)

4.3 pstree

        查看进程关系(关系树、类似于族谱)

4.4 ps -aux (ps -aux | less)

        查看进程状态信息

4.5 kill

        kill     -9  进程PID(9强制关闭)
        killall -9  进程名 (杀死所有与进程名相关的进程
        killall -9  bash(关闭所有)

5. 进程相关函数接口

5.1 fork

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.2 getpid

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.3 getppid

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.4 exit

        1. 定义

        2. 功能

                让进程结束(刷新缓冲区)

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.5 _exit

        1. 定义

        2. 功能

                立即结束调用该函数的进程(不刷新缓冲区)

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.6 wait(阻塞回收) 

        1. 定义

        2. 功能

                阻塞回收子进程空间(随机回收)

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

                wait具有阻塞功能


                WIFEXITED(wstatus)——1正常退出、0异常退出
                检测子进程是否正常退出
                
                WEXITSTATUS(wstatus)——返回子进程的ID号
                检测子进程退出的值
        
                WIFSIGNALED(wstatus)——1子进程被信号杀死、0子进程没被信号杀死
                检测子进程是否被信号杀死
        
                WTERMSIG(wstatus)——返回杀死进程的信号数
                检测子进程被几号信号杀死

5.7  waitpid(非阻塞回收)

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.8 getenv

        1. 定义

        2. 功能

                获得环境变量name对应的数值

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.9  setenv

        1. 定义

        2. 功能

                添加或者修改环境变量的值

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

5.10 system 

        1. 定义

        2. 功能

                加载一条shell命令

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

6. exec函数族

        利用进程空间执行另一段代码

        用fork创建子进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支),
进程往往要调用一种exec函数以执行另一个程序。当进程调用一种exec函数时,该进程
用户空间代码和数据完全被新程序替换,从新程序的启动例程开始执行。调用exec并不创建
进程,所以调用exec前后该进程的id并未改变。

      l:执行另一段代码参数以列表形式传递
      v:执行另一段代码参数以指针数组形式传递
      p:执行另一段代码文件在系统环境变量PATH对应的路径下查找
      e:执行另一段代码,更新环境变量

6.1 execl

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

6.2 execlp

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

6.3 execle

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

6.4 execv

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

6.5 execvp

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

6.6 execvpe

        1. 定义

        2. 功能

        3. 参数

        4. 返回值

        5. 示例程序

        6. 注意

7. 进程消亡

7.1 僵尸进程

        进程代码执行结束,空间没有被回收

        当子进程(child process)先于父进程(parent process)退出,但是父进程没有调用wait/waitpid回收子进程的资源,则子进程变成僵尸进程

7.2 如何避免产生僵尸进程

        1.让父进程先结束,子进程会成为孤儿进程,被系统进程收养,子进程结束系统进程
          回收子进程空间
        2.子进程结束,父进程回收子进程空间,即可避免产生僵尸进程


http://www.ppmy.cn/news/1468710.html

相关文章

03-240605-Spark笔记

03-240605 1. 行动算子-1 reduce 聚合 格式: def reduce(f: (T, T) > T): T 例子: val sparkConf new SparkConf().setMaster("local[*]").setAppName("Operator")val sc new SparkContext(sparkConf) ​val rdd sc.makeRDD(List(1…

蓄电池MSDS报告办理 锂电池运输鉴定中英文报告申请

MSDS 指的是化学产品安全技术说明书 MSDS 报告一般是由工厂所出具的,但也逐渐的应用在各种贸易过程当中,在海运过程当中,相关的产品也需要提供 MSDS 认证报告,不过有些人对于 MSDS 认证所规定的内容不是很了解,接下来大…

Web前端答辩PPT模板:全面解析与高效呈现

Web前端答辩PPT模板:全面解析与高效呈现 在Web前端领域,一个优秀的答辩PPT模板不仅能够充分展示项目成果,还能有效传达技术实力和创新思维。本文将从四个方面、五个方面、六个方面和七个方面,详细解析如何打造一个高质量的Web前端…

腾讯云和windows11安装frp,实现内网穿透

一、内网穿透目的 实现公网上,访问到windows上启动的web服务 二、内网穿透的环境准备 公网服务器、windows11的电脑、frp软件(需要准备两个软件,一个是安装到公网服务器上的,一个是安装到windows上的) frp下载地址下载版本 1.此版本(老版…

智慧城市的规划与实施:科技引领城市运行效率新飞跃

随着信息技术的飞速发展,智慧城市的构想正逐步成为现实。作为地理信息与遥感领域的研究者,我深知在这一转型过程中,技术的创新与应用是提升城市运行效率的关键。本文旨在探讨如何利用地理信息系统(GIS)、遥感技术、大数…

WPF Frame应用 实现页面跳转

需求: 有一个F0View主页面入口,三个子页面(First.xaml/Second.xaml/Third.xaml)用Frame默认加载第一个页面 First.xaml。实现三个页面之间顺序跳转,并且每个页面只初始化一次。 实现: 1,将三…

通过 CartPole 游戏详细说明 PPO 优化过程

CartPole 介绍 在一个光滑的轨道上有个推车,杆子垂直微置在推车上,随时有倒的风险。系统每次对推车施加向左或者向右的力,但我们的目标是让杆子保持直立。杆子保持直立的每个时间单位都会获得 1 的奖励。但是当杆子与垂直方向成 15 度以上的…

Ceph入门到精通-Ceph OSD 磁盘在系统重启后无法识别处理步骤

如果Ceph OSD磁盘在系统重启后无法识别,你可以按照以下步骤进行检查和解决: 1. 检查硬件状态 物理检查:首先进行物理检查,确保磁盘没有物理损坏,数据线和电源线连接正常。S.M.A.R.T状态:使用smartctl命令检查磁盘的S.M.A.R.T状态,以确定是否有硬件问题。2. 确认磁盘识别…