进程替换函数组介绍exec*

news/2024/12/5 0:40:44/

目录

前述

execl

execlp

execle

execv

execvp

 execvpe


前述

介绍后缀的意义:

l (list):表示参数采用列表。

v(vector):参数同数组表示。

p(path):自动搜索环境变量(路径+程序名=>程序名)。

e(env):手动维护环境变量。

execl

int execl(const char *path, const char *arg, ...);

path:路径+程序名字的字符串

arg:类似控制台输入 这里arg可以有多个必须以NULL结尾

调用ls指令
execl("/usr/bin/ls", "ls","-a","-l",NULL);

execlp

int execlp(const char *file, const char *arg, ...);

file:自动在环境变量寻找路径,只需要传入程序名

arg:类似控制台输入 这里arg可以有多个必须以NULL结尾

调用ls指令
execlp("ls"/*file*/,"ls","-a","-l",NULL);

execle

int execle(const char *path, const char *arg,..., char * const envp[]);

path:路径+程序名字的字符串

arg:  类似控制台输入 这里arg可以有多个必须以NULL结尾

env:  手动维护环境变量。

调用ls指令
char*env[]={"PATH=/usr/bin/ls",NULL};
execlp("/usr/bin/ls", "ls","-a","-l",NULL,env);

execv

int execv(const char *path, char *const argv[]);

path:路径+程序名字的字符串

argv:使用数组argv代替输入多个arg参数

调用ls指令
char*argv[]={"ls","-a","-l",NULL};
execv("/usr/bin/ls",argv);

execvp

int execvp(const char *file, char *const argv[]);

file:自动在环境变量寻找路径,只需要传入程序名

argv:使用数组argv代替输入多个arg参数

调用ls指令
char*argv[]={"ls","-a","-l",NULL};
execvp("ls",argv);

 execvpe

int execvp(const char *file, char *const argv[]);

file:自动在环境变量寻找路径,只需要传入程序名

argv:使用数组argv代替输入多个arg参数

env:  手动维护环境变量。

调用ls指令
char*env[]={"PATH=/usr/bin/ls",NULL};
execvpe("ls", "ls","-a","-l",NULL,env);

execve(系统函数)==execvpe

 int execve(const char *filename, char *const argv[],char *const envp[]);

file:自动在环境变量寻找路径,只需要传入程序名

argv:使用数组argv代替输入多个arg参数

env:  手动维护环境变量。

这个接口是系统接口函数,我们一般都是用其他接口函数,其实这些进程替换函数是基于execve为底层的上层封装函数。


各关系关系图谱

 其实,其他进程替换函数都是基于execve(系统函数)的上层封装函数。


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

相关文章

IP协议基础

文章目录 基本概念IP和TCP分别解决什么问题 以下过程都是在网络层完成的网段划分路由路由转发过程路由表 基本概念 主机: 配有IP地址, 但是不进行路由控制的设备。 路由器: 即配有IP地址, 又能进行路由控制。 节点: 主机和路由器的统称。 IP和TCP分别解决什么问题 TCP解决…

Acwing1293. 夏洛克和他的女朋友

夏洛克有了一个新女友(这太不像他了!)。 情人节到了,他想送给女友一些珠宝当做礼物。 他买了 n 件珠宝,第 i件的价值是 i1,也就是说,珠宝的价值分别为 2,3,…,n1。 华生挑战夏洛克&#xff0…

算法DAY52 动态规划10 300.最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组

300.最长递增子序列 五部曲: 1、dp数组的含义: dp[ i ] : 代表 截至到nums[i] (包括 nums[i]) 的序列中,以nums[i] 结尾的,最长递增子序列的长度。这里强调以nums[i] 结尾,是因为还要跟nums[j]做对比,确定…

106.(cesium篇)cesium椎体旋转

听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行完整代码包,运行如有问题,可“私信”博主。 效果如下所示: 下面献上完整代码,代码重要位置会做相应解释 <html lang="en"> <

互联网摸鱼日报(2023-05-08)

互联网摸鱼日报&#xff08;2023-05-08&#xff09; InfoQ 热门话题 数据库内核杂谈&#xff08;三十二&#xff09;- 杂谈五周年特别篇 比Python快35000倍&#xff01;LLVM&Swift之父宣布全新编程语言Mojo&#xff1a;编程被颠覆了 李彦宏回应文心一言与ChatGPT差距2个…

【Vue学习笔记4】基于Vue3的Composition API + <script setup>

继续前面的学习笔记。 1. 写一个累加器组件 在 src 下的 components 目录下新建一个 Counter.vue &#xff0c;并在这个文件里写出下面的代码&#xff1a; <template><div><h1 click"add">{{ count }}</h1></div> </template>…

代码随想录刷题-栈与队列-删除字符串中的所有相邻重复项

文章目录 删除字符串中的所有相邻重复项习题栈string实现 删除字符串中的所有相邻重复项 本节对应代码随想录中&#xff1a;代码随想录&#xff0c;对应视频链接为&#xff1a;暂无 习题 题目链接&#xff1a;1047. 删除字符串中的所有相邻重复项 - 力扣&#xff08;LeetCod…

第三章数据链路层

1.数据链路层的概述 1.0地位 数据链路层在网络体系结构中所处的地位 链路(Link)就是从一个结点到相邻结点的一段物理线路&#xff0c;而中间没有任何其他的交换结点。数据链路(Data Link)是指把实现通信协议的硬件和软件加到链路上&#xff0c;就构成了数据链路。数据链路层以帧…