exec函数族:进程替换函数
1、何为进程替换:
1、让父子进程执行不相干的操作;也就是说,在一个运行的程序a中,调用另外的应用程序b。
2、换核不换壳;exec族函数,能够替换进程地址空间中的代码段.text段(对应的堆、栈中的数据都会改变),重新填充新的代码。
2、函数原型:
execl系列是变参函数
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[]);
execv系列是不变参函数
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[]);
3、注意事项:
引用头文件:#include<unistd.h>
在执行exec族函数之前需要先fork();
返回值:如果exec族函数执行成功,则不返回;如果执行失败,打印错误信息,退出当前进程。
4、理解exec族函数:
带p的函数:执行PATH环境变量能够搜索到的程序,不用写全路径,一般是系统应用程序,如命令ls等。
带e的函数:执行指定目录下的应用程序(自己写全路径),一般用来执行自己写的程序。
不带e和p的函数:执行指定目录下的应用程序(自己写全路径),一般用来执行自己写的程序。
参数有char *const envp[]的:需要自己指明环境变量(默认查找路径)在envp[]数组中;比如:char* const ps_envp[] = {"PATH=/bin:/usr/bin","TERM=console",NULL}。
5、应用:
例1、让父进程循环输出1~10,子进程执行hello程序
int main()
{
pid_t pid;
char* const h_argv[] = {"hello",NULL};
int i = 0;
for(;i < 10; i++)//父进程数数
{
printf("====%d====\n",i);
}
pid = fork();
if(pid == 0)//子进程调用hello程序
{
//execl("/home/djh/linux/hello","hello",NULL);
execv("/home/djh/linux/hello",h_argv);
}
int j = 0;
for(;j < 3; j++)
{
printf("qqq\n");
}
return 0;
}
例2、让父进程循环输出1~10,子进程执行ls命令
int main()
{
pid_t pid;
char* const ls_argv[] = {"ls","-a",NULL};
int i = 0;
for(;i < 10; i++)//父进程数数
{
printf("====%d====\n",i);
}
pid = fork();
if(pid == 0)//子进程调用ls
{
//execlp("ls","ls","-a",NULL);
execvp("ls",ls_argv);
perror("execlp");//如果执行失败,则打印错误信息
exit(1);//退出当前进程
}
int j = 0;
for(;j < 3; j++)
{
printf("qqq\n");
}
return 0;
}
————————————————
版权声明:本文为CSDN博主「djh971102」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/djh971102/article/details/97298322