Linux中exec系列函数简单用法

这段代码是一个简单的C程序,它首先打印出当前进程ID(PID)和父进程ID(PPID),然后使用execve系统调用执行ps-f命令,展示进程树信息。程序尝试了不同的execl家族函数,但最终选择了execve,因为它允许传递环境变量。
摘要由CSDN通过智能技术生成
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>

int main(int argc, char *argv[], char *envp[]) {
  printf("main pid=%d,ppid=%d", getpid(), getppid());
  //   execl("/usr/bin/ps","ps","-f",(char*)0);
  //   execlp("ps", "ps", "-f", (char *)0);
  //   execle("/usr/bin/ps", "ps", "-f", (char *)0,envp);
  char *myargv[] = {"ps", "-f", 0};
  //   execv("/usr/bin/ps", myargv);
  execve("/usr/bin/ps",myargv,envp);//终极形式
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: exec函数Linux的一个系统调用,用于执行一个新的程序,取代当前进程的执行。它的具体用法如下: 1. int execv(const char *path, char *const argv[]) 该函数用于执行指定路径下的可执行文件,其path是可执行文件的路径,argv是一个指向参数列表的指针数组。 2. int execl(const char *path, const char *arg, ...) 该函数用于执行指定路径下的可执行文件,其path是可执行文件的路径,arg是可执行文件的第一个参数,后面可以跟多个参数。 3. int execvp(const char *file, char *const argv[]) 该函数用于执行指定文件名的可执行文件,其file是可执行文件的文件名,argv是一个指向参数列表的指针数组。 4. int execlp(const char *file, const char *arg, ...) 该函数用于执行指定文件名的可执行文件,其file是可执行文件的文件名,arg是可执行文件的第一个参数,后面可以跟多个参数。 以上就是exec函数的具体用法,需要注意的是,exec函数执行成功后,当前进程的代码段、数据段、堆栈等都会被新程序替换,因此在执行exec函数后,原来的程序代码不会再执行。 ### 回答2: exec 函数Linux 系统非常常见的一个函数之一,它通常用于执行一个新的进程,同时替代当前进程的镜像。这个函数参数多,既可以用于普通的进程,也可以用于线程等其他一些特殊的任务。 exec 函数有多种不同的变种,其几个常见的如下: 1. execl / execle / execlp / execv / execve / execvp 这些函数的作用大致相同,只是传入参数方式不同。其exec 函数后面跟的是表示可执行程序路径的字符串,而后面跟的参数则是用空格隔开的一系列字符串,表示执行该程序时的参数。 2. system system 函数也可以执行可执行程序,但它的参数是一个以空格隔开的命令行字符串,而非一个包含可执行程序名称和参数的数组。 exec 函数,尤其是 execve 函数可以用于进程完全替换和动态库载入等场景,而 system 函数在实现上通常也是使用了 exec 函数族的某个函数。 使用 exec 函数时,有一些需要注意的问题: 第一,exec 函数会替换当前进程映像,不会返回。因此,在调用 exec 函数之前,通常需要处理一些文件描述符、进程信号处理等事务,确保子进程可以正确运行。 第二,exec 函数通常还需要设置一些环境变量,以使得子进程能够正常运行。例如,子进程需要使用的环境变量、动态链接库等,都需要在 exec 函数调用时指定。在使用 exec 函数时,需要注意这些具体的参数和配置,确保子进程能够正确启动。 ### 回答3: exec函数是一个在Linux操作系统常用的C语言函数,它可以用于在当前进程执行一个新程序。exec函数能够动态地将已经存在的可执行程序读入到当前进程并执行,这个过程会替换掉当前进程的代码段、数据段和堆栈,但是保留了当前进程的PID以及文件描述符。 exec函数是由五个子函数组成的,分别是execl、execlp、execle、execv、execvp。它们的参数和功能略有不同: 1. execl函数:可将变长参数列表(command和arguments)传递给一个新程序。 ```C #include <unistd.h> int execl(const char *pathname, const char *arg, ...); //pathname: 新程序的路径。 //arg: 新程序名。参数列表,最后一个参数必须是NULL。 //返回值:成功则不返回,失败则返回-1。 ``` 2. execlp函数:与execl函数用法相同,只是新程序在当前进程的PATH路径搜索,无需指定新程序路径。 ```C #include <unistd.h> int execlp(const char *file, const char *arg, ...); //file: 新程序名。参数列表,最后一个参数必须是NULL。 //返回值:成功则不返回,失败则返回-1。 ``` 3. execle函数:与execl函数用法相同,不同的是它支持传递环境变量参数。 ```C #include <unistd.h> int execle(const char *pathname, const char *arg, ... /*, char * const envp[]*/); //pathname: 新程序的路径。 //arg: 新程序名。参数列表,最后一个参数必须是NULL。 //envp:指向新程序的环境变量数组。最后一个参数必须是NULL。 //返回值:成功则不返回,失败则返回-1。 ``` 4. execv函数:与execl函数类似,只是将参数列表改为指向字符串数组的指针。arg1到arg[n-1]为新程序的参数。这里需要将参数打包成数组传递给execv函数。 ```C #include <unistd.h> int execv(const char *pathname, char *const argv[]); //pathname: 新程序的路径。 //argv: 新程序的参数的数组。数组的最后一个元素必须是NULL。 //返回值:成功则不返回,失败则返回-1。 ``` 5. execvp函数:与execv函数用法类似,只是会在当前进程的PATH路径搜索新程序,无需指定新程序路径。 ```C #include <unistd.h> int execvp(const char *file, char *const argv[]); //file: 新程序的名字。 //argv: 新程序的参数的数组。数组的最后一个元素必须是NULL。 //返回值:成功则不返回,失败则返回-1。 ``` 总结一下,exec函数可以执行一个新程序并且替换当前进程的代码段、数据段和堆栈,保留当前进程的PID以及文件描述符。根据参数不同,exec函数可以分为五种用法execl、execlp、execle、execv和execvp。需要注意的是参数列表需要以NULL结尾,否则会引起内存错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值