exec族有六个函数,函数原型是:
int execl(const char *pathname, const char *arg0, ... /* (char *)0 */);
int execv(const char *pathname, char *argv[] );
int execle(const char *pathname, const char *arg0, ... /* (char *)0, char *const envp[] */);
int execve(const char *pathname, char *const argv[], char *const envp[] );
int execlp(const char *pathname, const char *arg0, ... /* (char *)0 */);
int execvp(const char *pathname, char *const argv[]);
第一个区别:
前四个函数的第一个参数要取执行命令的完整路径为参数,后两个函数取命令的文件名做参数:
如:
execl("/bin/ls", "ls", "-al", "/etc/passwd", (char *)0 );
execlp("ls", "ls", "-al", "/etc/passwd", (char *)0 );
观察一下就会发现前四个函数的函数名都没有p,他们需要有完整的路径名做第一个参数;后两个函数有p,只需要程序名做参数即可。
个人记忆:p代表path,函数名中有p的则第一个参数不需要不需要程序的完整的路径(path)。
第二个区别:与参数表有关(l表示list,v表示矢量vector)。函数execl、execlp、execle要求将新程序的每个命令行参数都说明为一个单独参数。
如:
execlp("ls", "ls", "-al", "/etc/passwd", (char *)0 );execlp("ls", "ls", "-al", "/etc/passwd", (char *)0 );
char *argv[] = {"ls", "-al", "/etc/passwd", (char *)0 };
execv("/bin/ls", argv,);
个人记忆:也就是说函数名中带l的他们每个参数都说明为一个单独的参数,而且参数的最后以(char *)0 结束;
而函数名中带v的,他们的命令和参数都存放在一个二维数组中,通过二维指针传递给函数。
第三个区别:与向新程序传递环境表有关。以e结尾的两个函数(execle和execve)可以传递一个指向新环境字符串指针数组的指针。而其他四个函数则使用调用进程中的environ变量为新程序复制现有的环境。
如:
execl("/bin/ls", "ls", "-al", "/etc/passwd", (char *)0 );
char *env_init[] = { "USER=unknow", "PATH=/tmp",NULL};
execle("/home/sar/bin/echoall", "echoall", "myarg", (char *)0, env_init);
这6个exec函数的参数很难记忆。函数名中的字符给我们一些帮助。字母p表示该函数取filename作为参数,并且用PATH环境变量寻找可执行文件。字母l表示该函数取一个参数表,它与字母v互斥。v表示该函数取一个argv[]矢量。最后,字母e表示该函数取envp[]数组,而不是使用当前环境。