Linux :进程的程序替换

目录

一、什么是程序替换

1.1程序替换的原理

1.2更改为多进程版本

二、各种exe接口

2.2execlp

 ​编辑

2.2execv

2.3execle、execve、execvpe


一、什么是程序替换

1.1程序替换的原理

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

就相当于在执行一个程序时,要从磁盘中将新的数据和代码加载到内存中,将老程序的数据和代码替换掉,这个现象就叫做程序替换。程序替换过程中并没有创建新的进程,而作为用户我们没有资格去直接进行程序替换,所以如果想实现程序替换,就必须使用系统调用execl。

即pcb这个内核数据结构不换,代码和数据换了。

第一个参数*Path是要寻找的程序,第二个参数*arg表示你想如何执行,而最后的...是可变参数列表。

我们可以通过这个指令来对ls指令进行模拟。

可以看到 ls命令很顺利的执行了,可pccontrol.c最后一个一个printf却没有执行,这是为什么呢?

答案很简单,因为程序被替换了。

execl只有失败返回没有成功返回。 比如给定一个不存在的路径。此时执行完毕后如果去echo $?就可以看到错误码为1。如果成功替换完成,不创建新的进程。

 而我们创建一个进程,是先创建PCB、地址空间、页表,然后再把程序加载到内存,而程序替换所做的工作就是加载。

1.2更改为多进程版本

 我们也可以创建一个子进程,让子进程去进行程序替换,这样父进程就可以得到运行结果,因为进程具有独立性,创建子进程后,当要让子进程去进行程序替换时就会发生写实拷贝,开辟新的空间,这样就不会影响父进程。

所以我们的shell运行原理我们也可以类推出来,当我们在shell中输入指令时,就会创建一个子进程,然后shell去wait等待子进程,子进程进行程序替换发生写时拷贝开辟新的空间,然后去执行。

二、各种exe接口

我们可以看到,一共有6个接口, 加上execv一共有7个接口。

2.2execlp

 

execlp,最后为p(PATH)的不需要告诉操作系统绝对路径,只需要告诉文件名。系统进行替换时会自动去PATH环境变量中查找。

 

最后的执行结果和execl是一样的 。

2.2execv

第一个参数是绝对或相对路径,第二个参数是argv,即命令行参数表,类似于main函数的参数。

而exec结尾为l表示list,即将元素以链表的形式传。

而v结尾表示vector,即以数组形式传。

execvp类比于上面的execlp

exec*可以执行系统的指令,也可以执行自己的程序,无论是什么语言,都可以在linux下跑。因为所有的语言运行之后都是进程。

2.3execle、execve、execvpe

这些函数原型看起来很容易混,但只要掌握了规律就很好记。
l(list) : 表示参数采用列表
v(vector) : 参数用数组
p(path) : 有p自动搜索环境变量PATH
e(env) : 表示自己维护环境变量

区别就是最后带上了环境变量的一个参数。

首先如果不使用带环境变量的调用,可以通过显示传的方式传给操作系统。我们也可以在C语言写的程序中去通过传参给一段C++ 代码编译成的可执行程序。

通过以上我们可以看到,通过子进程完成了进程切换成功运行了mytest文件并且将命令行参数传给了mytest的argv,父进程也成功回收了子进程。


以上传了命令行参数,那环境变量该如何传给要替换的程序呢?

当我们不显示去传环境变量表时会发生什么呢? 

子进程默认可以通过地址空间继承的方式,让所有子进程拿到环境变量。

进程程序替换,不会替换环境变量数据。

1.如果我们想让子进程继承全部的环境变量,直接就能拿到

2.如果单纯新增的话使用putenv("GA=AAAAAA");

3.如果想设置全新的环境变量,就可以用到execle


再次运行,环境变量就变成我们设置的全新的环境变量了,也叫覆盖方式。

 而这么多的接口功能上基本上不存在太大的差异,只是传参的区别以及使用方式不同,而程序替换真正的系统调用只有一个,就是上图所示的execve,其余所有的调用都是封装了execve。

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

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

相关文章

LongAdder 和 Striped64 基础学习

cs,表示 Cell 数组的引用;b,表示获取的 base 值,类似于 AtomicLong 中全局变量的 value 值,在没有竞争的情况下数据直接累加到 base 上,或者扩容时,也需要将数据写入到 base 上;v&am…

32-2 APP渗透 - 移动APP架构

前言 app渗透和web渗透最大的区别就是抓包不一样 一、客户端: 反编译: 静态分析的基础手段,将可执行文件转换回高级编程语言源代码的过程。可用于了解应用的内部实现细节,进行漏洞挖掘和算法分析等。调试: 排查软件错误的一种手段,用于分析应用内部原理和行为。篡改/重打…

Unity | Shader基础知识(第十一集:什么是Normal Map法线贴图)

目录 前言 一、图片是否有法线贴图的视觉区别 二、有视觉区别的原因 三、法线贴图的作用 四、信息是如何存进去的 五、自己写一个Shader用到法线贴图 六、注意事项 七、作者的话 前言 本小节会给大家解释,什么是法线贴图?为什么法线贴图会产生深…

GPT4不限制使用次数了!GPT5即将推出了!

今天登录到ChatGPT Plus账户,出现了如下提示: 已经没有了数量和时间限制的提示。 更改前:每 3 小时限制 40 次(团队计划为 100 次);更改后:可能会应用使用限制。 GPT-4放开限制 身边订阅了Ch…

C++多线程:单例模式与共享数据安全(七)

1、单例设计模式 单例设计模式,使用的频率比较高,整个项目中某个特殊的类对象只能创建一个 并且该类只对外暴露一个public方法用来获得这个对象。 单例设计模式又分懒汉式和饿汉式,同时对于懒汉式在多线程并发的情况下存在线程安全问题 饿汉…

【原创】基于分位数回归的卷积长短期结合注意力机制的神经网络(CNN-QRLSTM-Attention)回归预测的MATLAB实现

基于分位数回归的卷积长短期结合注意力机制的神经网络(CNN-QRLSTM-Attention)是一种用于时间序列数据预测的深度学习模型。该模型结合了卷积神经网络(CNN)、长短期记忆网络(LSTM)和注意力机制(A…

C语言实现通讯录(从0-1的项目)

一、前言 1、实现通讯录首先我们要了解并懂得如何通过C语言来完成有关顺序表的实现 2、需要了解的内容:如何使用顺序表结构实现增、删、改、查等操作 二、顺序表的认识和实现 1、什么是顺序表 最基础的数据结构就是数组。 顺序表则是线性表的一种,…

图片改大小尺寸怎么改?几个修改图片尺寸的方法

日常生活和工作中,图片的大小和尺寸对于我们的工作和生活都至关重要,因此我们经常需要调整图片的大小。我们都知道压缩图是一款功能强大的图片在线处理工具,那么用它怎么调整图片大小呢?下面就让我们一起来看一下具体的操作步骤。…

基于Spring Boot的在线考试系统

开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7(一定要5.7版本) 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea Maven…

实时渲染 -- 材质(Materials)

一、自然界中的材质 首先了解下自然界中的材质 如上这幅图,不同的物体、场景、组合,会让我们看到不同的效果。 我们通常认为物体由其表面定义,表面是物体和其他物体或周围介质之间的边界面。但是物体内部的材质也会影响光照效果。我们目前只…

微服务(基础篇-008-es、kibana安装)

目录 05-初识ES-安装es_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1LQ4y127n4?p81&vd_source60a35a11f813c6dff0b76089e5e138cc 1.部署单点es 1.1.创建网络 1.2.加载镜像 1.3.运行 2.部署kibana 2.1.部署 2.2.DevTools 3.安装IK分词器 3.1.在线安装ik…

【IP组播】PIM-SM的RP、RPF校验

目录 一:PIM-SM的RP 原理概述 实验目的 实验内容 实验拓扑 1.基本配置 2.配置IGP 3.配置PIM-SM和静态RP 4.配置动态RP 5.配置Anycast RP 二: RPF校验 原理概述 实验目的 实验内容 实验拓扑 1.基本配置 2.配置IGP 3.配置PIM-DM 4.RPF校…

【洛谷 P8695】[蓝桥杯 2019 国 AC] 轨道炮 题解(映射+模拟+暴力枚举+桶排序)

[蓝桥杯 2019 国 AC] 轨道炮 题目描述 小明在玩一款战争游戏。地图上一共有 N N N 个敌方单位,可以看作 2D 平面上的点。其中第 i i i 个单位在 0 0 0 时刻的位置是 ( X i , Y i ) (X_i, Y_i) (Xi​,Yi​),方向是 D i D_i Di​ (上下左右之一, 用…

基于Spring Boot的餐厅点餐系统

基于Spring Boot的餐厅点餐系统 开发语言:Java框架:springbootJDK版本:JDK1.8数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:Maven3.3.9 部分系统展示 管理员登录界面 用户注册登录界面 …

股权激励和期权激励对比辨析

文章目录 概念定义 收益方式 风险评估 应用和分析 股权激励和期权激励,两者的区别是什么,本文就来梳理对比一下。 概念定义 股权激励,是指上市公司以本公司股票为标的,对其董事、高级管理人员及其他员工进行的长期性激励。取得…

JVM专题——类文件加载

本文部分内容节选自Java Guide和《深入理解Java虚拟机》, Java Guide地址: https://javaguide.cn/java/jvm/class-loading-process.html 🚀 基础(上) → 🚀 基础(中) → 🚀基础(下&a…

C++从入门到精通——入门知识

1. C关键字(C98) C总计63个关键字,C语言32个关键字 2. 命名空间 在C/C中,变量、函数和后面要学到的类都是大量存在的,这些变量、函数和类的名称都将存在于全局作用域中,可能会导致很多冲突。使用命名空间的目的就是对标识符的名…

ST表---算法

相当于二分的思想,一直比较最值 ST的创建 现在创建成功,是应该如何查询的问题 ST表的查询 虽然这两区间有重叠,但是可以一个往前数,一个往后数,互不影响 时间复杂度 创建st表的复杂度为n*logn 使用时的复杂度为O(…

【机器学习】K-近邻算法(KNN)介绍、应用及文本分类实现

一、引言 1.1 K-近邻算法(KNN)的基本概念 K-近邻算法(K-Nearest Neighbors,简称KNN)是一种基于实例的学习算法,它利用训练数据集中与待分类样本最相似的K个样本的类别来判断待分类样本所属的类别。KNN算法…

Golang 哈希表底层实现原理

1、本文讨论Golang的哈希表 Golang哈希表的实现,底层数据结构是数组单链表,链表节点由8个key、value和键的高八位组成的。为了方便理解,先简单看一个图快速理解。 我们来看一下Golang哈希表的结构体定义 简单介绍一下结构体中几个关键的…