目录
一、替换原理
当一个进程调用exec函数时,该进程的用户空间代码和数据完全被新程序替换,从新程序的启动例程开始执行。可以看到代码中exec函数后,printf("command end..\n");代码也会被覆盖不会执行。
调用exec不会创建新进程,该进程id不会改变。
通常是fork生成子进程后,子进程的程序与父进程相同。为了让子进程执行与父进程不同的事,可让子进程调用exec函数进行程序替换.
#include <stdio.h>
#include <unistd.h>
int main()
{
printf("command begin..\n");
execl("/usr/bin/ls","ls","-a","-l","-i",NULL);
printf("command end..\n");
return 0;
}
二、替换函数
1.介绍
exec类的替换函数有7个,但是事实上,只有execve是真正的系统调用,其它六个函数最终都调用 execve。
int execl(const char *path, const char *arg, ...);
int execlp(const char *file, const char *arg, ...);
int execle(const char *path, const char *arg, ...,char *const envp[]);
int execv(const char *path, char *const argv[]);
int execvp(const char *file, char *const argv[]);
int execve(const char *path, char *const argv[], char *const envp[]);
这些函数一旦执行,就会从替换的新的程序开始执行,不会再返回。
如果调用出错会返回-1。
2.用法
exec后跟着字母l、p、v、e,分别表示不同的含义,根据不同的参数要求传入来使用具体的exec函数。
l(list) : 表示参数采用列表
v(vector) : 参数用数组
p(path) : 有p自动搜索环境变量PATH
e(env) : 表示自己维护环境变量
1 #include <stdio.h>
2 #include <unistd.h>
3
4 int main()
5 {
6 printf("command begin..\n");
7 char* argv[] = {"ls","-a","-l","-i",NULL};
8 char* envp[] = {"PATH=/usr/bin","TERM=console",NULL};
9 //参数采用列表
10 execl("/usr/bin/ls","ls","-a","-l","-i",NULL);
11 //参数采用数组
12 execv("/usr/bin/ls",argv);
13 //自动搜索环境变量,不用输入全路径
14 execlp("ls","ls","-a","-l","-i",NULL);
15 execvp("ls",argv);
16 //自己配置环境变量
17 execle("ls","ls","-a","-i",NULL,envp);
18 execve("/usr/bin/ls",argv,envp);
19 printf("command end..\n");
20 return 0;
21 }