exec函数族的作用是根据指定的文件名找到可执行文件,并用它来取代调用进程的内容,换句话说,就是在调用进程内部执行一个可执行文件。这里的可执行文件既可以是二进制文件,也可以是任何Linux下可执行的脚本文件。
与一般情况不同,exec函数族的函数执行成功后不会返回,因为调用进程的实体,包括代码段,数据段和堆栈等都已经被新的内容取代,只留下进程ID等一些表面上的信息仍保持原样,颇有些神似"三十六计"中的"金蝉脱壳"。看上去还是旧的躯壳,却已经注入了新的灵魂。只有调用失败了,它们才会返回一个-1,从原程序的调用点接着往下执行。
第5位
l:表示参数传递为逐个列举方式
execl、execle、execlp
v:表示参数传递为构造指针数组方式
execv、execve、execvp
第6位
e:可传递新进程环境变量
execle、execve
p:表示系统会自动从环境变量“$PATH”所指出的路径中查找可执行程序。
execlp、execvp
1.execve
#include<unistd.h>
函数定义 :
int execve(const char *filename, char *const argv[ ], char *const envp[ ]);
返回值:
函数执行成功时没有返回值,执行失败时的返回值为-1.
函数说明:
execve()用来执行参数filename字符串所代表的文件路径,第二个参数是利用数组指针来传递给执行文件,并且需要以空指针(NULL)结束,最后一个参数则为传递给执行文件的新环境变量数组。
2.execlp实例
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char* argv[])
{
execlp(“ls”,“ls”,”-l”,”/home”, NULL);
return 0;
}
3.execle实例
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
int main()
{
char *envp[]={"PATH=/tmp","USER=zhanSan",NULL};
if(fork()==0){
/*调用execle函数,注意这里也要指出env的完整路径*/
if(execle("/bin/env","env",NULL,envp)<0)
perror("execle error!");
}
exit( 0);
}
4.execvp实例
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
main()
{
char *argv[] = {"ls","-l","/etc",(char *)0};
execvp("ls",argv);
return 0;
}
更多的组合实例,具体应用欢迎大家看我其他的进程博客
与一般情况不同,exec函数族的函数执行成功后不会返回,因为调用进程的实体,包括代码段,数据段和堆栈等都已经被新的内容取代,只留下进程ID等一些表面上的信息仍保持原样,颇有些神似"三十六计"中的"金蝉脱壳"。看上去还是旧的躯壳,却已经注入了新的灵魂。只有调用失败了,它们才会返回一个-1,从原程序的调用点接着往下执行。
#include <unistd.h>
int execl(const char *path, const char *arg, ..., NULL);
int execlp(const char *file, const char *arg, ..., NULL);
int execle(const char *path, const char *arg, ..., NULL ,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[]);
int execl(const char *path, const char *arg, ..., NULL);
int execlp(const char *file, const char *arg, ..., NULL);
int execle(const char *path, const char *arg, ..., NULL ,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[]);
注意:
exec函数一共有六个,其中execve为内核级系统调用,其他(execl,execle,execlp,execv,execvp)都是调用execve的库函数
exec函数一共有六个,其中execve为内核级系统调用,其他(execl,execle,execlp,execv,execvp)都是调用execve的库函数
第5位
l:表示参数传递为逐个列举方式
execl、execle、execlp
v:表示参数传递为构造指针数组方式
execv、execve、execvp
第6位
e:可传递新进程环境变量
execle、execve
p:表示系统会自动从环境变量“$PATH”所指出的路径中查找可执行程序。
execlp、execvp
1.execve
#include<unistd.h>
函数定义 :
int execve(const char *filename, char *const argv[ ], char *const envp[ ]);
返回值:
函数执行成功时没有返回值,执行失败时的返回值为-1.
函数说明:
execve()用来执行参数filename字符串所代表的文件路径,第二个参数是利用数组指针来传递给执行文件,并且需要以空指针(NULL)结束,最后一个参数则为传递给执行文件的新环境变量数组。
2.execlp实例
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char* argv[])
{
execlp(“ls”,“ls”,”-l”,”/home”, NULL);
return 0;
}
3.execle实例
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
int main()
{
char *envp[]={"PATH=/tmp","USER=zhanSan",NULL};
if(fork()==0){
/*调用execle函数,注意这里也要指出env的完整路径*/
if(execle("/bin/env","env",NULL,envp)<0)
perror("execle error!");
}
exit( 0);
}
4.execvp实例
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
main()
{
char *argv[] = {"ls","-l","/etc",(char *)0};
execvp("ls",argv);
return 0;
}
更多的组合实例,具体应用欢迎大家看我其他的进程博客