exec系列函数
在C语言编程中,exec
系列函数用于在当前进程中执行一个新程序,从而替换当前进程的映像。这些函数不会返回,除非发生错误。exec
系列函数有多个变体,其中最常用的包括 execl
, execle
, execlp
, execv
, execve
, execvp
等。这里主要讨论 exec
和 execve
两个函数。
exec
系列函数概述
exec
系列函数的行为大体相同,区别在于传递参数的方式和是否使用环境变量。以下是这些函数的一些共同点:
- 不返回:如果调用成功,这些函数不会返回,而是用新程序替换当前进程映像。如果失败,它们会返回 -1,并设置
errno
以指示错误类型。 - 参数传递:这些函数允许将参数列表传递给新程序,通常包括程序路径和命令行参数。
execve
execve
是 exec
系列函数中最底层的一个,它提供了最大的灵活性,因为它允许直接指定程序路径、参数列表和环境变量。
#include <unistd.h>int execve(const char *pathname, char *const argv[], char *const envp[]);
pathname
:要执行的程序文件的路径。argv
:传递给新程序的参数列表,其中argv[0]
通常是程序名,argv[n]
为 NULL 表示参数列表结束。envp
:传递给新程序的环境变量列表,其中每个环境变量都是一个name=value
字符串,列表以 NULL 结尾。
示例:使用 execve
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>int main() {char *args[] = {"/bin/ls", "-l", "/home", NULL};char *env[] = {NULL}; // 继承当前环境变量,也可以指定自定义环境变量// 使用 execve 执行 /bin/ls -l /homeif (execve("/bin/ls", args, env) == -1) {perror("execve failed");exit(EXIT_FAILURE);}// 这行代码不会被执行,因为 execve 成功的话不会返回return 0;
}
其他 exec
函数
其他 exec
函数是 execve
的变种,它们在参数传递和环境变量处理上有所不同:
execl
和execv
:这些函数直接接受参数列表和环境变量(或继承当前环境变量),但参数传递方式不同。execlp
和execvp
:这些函数接受程序名而不是路径,并使用 PATH 环境变量来查找程序。execle
:类似于execve
,但允许指定文件描述符的关闭和重定向操作。
示例:使用 execlp
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>int main() {char *args[] = {"ls", "-l", "/home", NULL};// 使用 execlp 执行 ls -l /home,从 PATH 环境变量中查找 lsif (execlp("ls", "ls", "-l", "/home", (char *)NULL) == -1) {perror("execlp failed");exit(EXIT_FAILURE);}// 这行代码不会被执行,因为 execlp 成功的话不会返回return 0;
}
总结
execve
是最底层、最灵活的exec
函数,允许直接指定程序路径、参数列表和环境变量。- 其他
exec
函数是execve
的变种,简化了参数传递和环境变量处理。 exec
系列函数在成功执行后不会返回,而是用新程序替换当前进程映像。