进程替换
1、exec 系列替换过程:只替换进程实体,pcb不变
exec 系类方法:
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[]);*
参数介绍:
*path:新替换的程序的路径名称
*arg :传给新程序主函数的第一个参数,一般为程序的名字
*arg 后面是剩余参数列表,参数个数可变,必须以空指针作为最后一个参数
*const envp[]:传给新程序的环境变量
2、以ps替换当前程序为例
1)查看ps命令所在目录
2)编写以下代码:
1 #include<stdio.h>
2 #include<unistd.h>
3 #include<stdlib.h>
4
5 int main()
6 {
7 printf("main pid = %d\n",getpid());
8 execl("/usr/bin/ps","ps","-f",(char*)0);
9 printf("execl error\n");
10
11 exit(0);
12 }
3)编译运行
分析运行结果我们发现,main程序的pid=143,当程序执行完 execl(“/usr/bin/ps”,“ps”,”-f”,(char)0);后,main程序被替换,替换成ps -f,ps -f的pid = 143,所以我们得出结论,当进程发生替换的时候只改变进程实体,不会改变pcb。*
3、其他exec 系列方法
其他exec 系列方法与execl功能相同,只是参数不同而已。上述代码用其他exec系列方法如下:
execlp:
execlp(“ps”,“ps”,”-f”(char)0);*
不用指定具体路径
execle:
expcle(“/usr/bin/ps”,“ps”,”-f”,(char*)0,envp);
envp当前主函数环境变量
execv:
char* myargv[10] = {“ps”,”-f”};
execv(“/usr/bin/ps”,myargv);
execvp:
char* myargv[10] = {“ps”,”-f”};
execvp(“ps”,myargv);
execve:
char* myargv[10] = {“ps”,”-f”};
execve(“ps”,myargv,envp);
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/95572.html