8 进程替换
进程替换exec系列:execl、 execlp、 execle、 execv、 execvp、 execve
8.1 exec 系列替换过程:
- pcb 使用以前的只修改,进程实体更换
以进程main替换为进程ps为例解释进程替换,首先将进程main全部释放掉,然后重新装载ps,运行ps,可以发现原来的pcb是不变的,只需要将pcb中的成员改一改即可,同时pid不变,将进程名字main删掉改为现在的ps,这就完成了替换,所以进程实体被换掉了,但是描述符不变,同时它的一些东西也会保留下来,即原来main程序的父进程是A,那么现在ps的父进程也是A,具体过程如下图:
8.1.1 exec 系列方法
- int execl(const char* path, const char * arg,…);
- *path:新替换的程序的路径名称
- *arg :传给新程序主函数的第一个参数,一般为程序的名字
- *arg 后面是剩余参数列表,参数个数可变,必须以空指针作为最后一个参数
示例如下:
-
int execlp(const char* file, const char * arg,…);
execlp与execl的区别 :execlp直接输入运行程序名即可,不需要输入路径。
-
int execle(const char* path, const char* arg,…, char* const envp[]); 其中,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[]);
部分代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <assert.h>
#include <string.h>
int main()
{
//存放传给新程序主函数的参数
char* myargv[] = {"ps","-f",(char*)0};
//存放传给新程序主函数的环境变量
char* myenvp[] = {"MYSTR=hello","VAL=100",(char*)0};
printf("main pid=%d\n",getpid());
//execl 执行成功不返回,失败返回错误码
execve("/bin/ps",myargv,myenvp);
perror("execve error");
exit(0);
}
注意: exec系列方法功能都一样,没有区别,只是参数不同
execl 执行成功不返回,直接从新程序的主函数开始执行,只有失败才返回错误码
申请malloc,1G内存能否成功?
- 1.物理内存剩余空间大于1G,能成功;
- 2.物理内存剩余空间小于1G,但是加上虚拟内存空闲的空间,大于1G,那么也能成功;