exec族函数
作用
在进程的创建上Unix采用了一个独特的方法,它将进程创建与加载一个新进程映象分离。这样的好处是有更多的余地对两种操作进行管理。
当我们创建了一个进程之后,通常将子进程替换成新的进程映象,这可以用exec系列的函数来进行。当然,exec系列的函数也可以将当前进程替换掉。
例如:在shell命令行执行ps命令,实际上是shell进程调用fork复制一个新的子进程,在利用exec系统调用将新产生的子进程完全替换成ps进程。
列表
#include <unistd.h>
extern char **environ;
int execl(const char *path, const char *arg, ...
/* (char *) NULL */);
int execlp(const char *file, const char *arg, ...
/* (char *) NULL */);
int execle(const char *path, const char *arg, ...
/*, (char *) NULL, char * const envp[] */);
int execv(const char *path, char *const argv[]);
int execvp(const char *file, char *const argv[]);
int execvpe(const char *file, char *const argv[],
char *const envp[]);
包含这几个函数,它们都是c函数,调用execve这个系统调用。
path参数表示你要启动程序的名称包括路径名
arg参数表示启动程序所带的参数,一般第一个参数为要执行命令名,不是带路径且arg必须以NULL结束
返回值:成功返回0,失败返回-1
1. 带l 的exec函数:execl,execlp,execle,表示后边的参数以可变参数的形式给出且都以一个空指针结束
#include <unistd.h>
#include <stdio.h>
#include <errno.h>
int main()
{
printf("---------- in main pro\n");
execl("/bin/ls", "ls", NULL);
printf("---------- not print\n");
perror("ls");
return 0;
}
利用execl将当前进程main替换掉,所有最后那条打印语句不会输出
2. 带 p 的exec函数:execlp,execvp,表示第一个参数path不用输入完整路径,只有给出命令名即可,它会在环境变量PATH当中查找命令
#include <unistd.h>
#include <stdio.h>
#include <errno.h>
int main()
{
printf("---------- in main pro\n");
execlp("ls", "ls", NULL);
printf("---------- not print\n");
perror("ls");
return 0;
}
3. 不带 l 的exec函数:execv,execvp表示命令所需的参数以char *arg[]形式给出且arg最后一个元素必须是NULL
#include <unistd.h>
#include <stdio.h>
#include <errno.h>
int main()
{
printf("---------- in main pro\n");
char *argv[] = {"ls", NULL};
execvp("ls", argv);
printf("---------- not print\n");
perror("ls");
return 0;
}
4. 带 e 的exec函数:execle表示,将环境变量传递给需要替换的进程
从上述的函数原型中我们发现:
extern char **environ;
此处的environ是一个指针数组,它当中的每一个指针指向的char为“XXX=XXX”
environ保存环境信息的数据可以env命令查看