前言
本文记录的是exec重载函数在子进程的使用方法
一、函数
二、示例代码
1.execl示例
代码如下(示例):
demo1的程序是:/* 创建一个进程,父进程1100,子进程1001,一秒数一下 */
exec.c
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
int main(int argc, char const *argv[])
{
int i = 0;
pid_t pid = fork();
if(pid) {
printf("我是父进程! 我的ID是:%d\n", getpid() );
} else{
printf("我是子进程! 我的ID是:%d\n", getpid() );
execl("./demo1", "demo1", NULL);
}
return 0;
}
效果如图所示
结果分析:
1 execl("./demo1" , “demo1” , NULL ); // 使用execl 函数进行转载新的可执行文件,、
2 //参数 : “./demo1” 需要执行的文件的路径+名字
3 // 参数 “demo1” 需要执行的文件的名字 开头表示开始
4 // …
5 // 参数 NULL 末尾表示结束
2.execv示例2
代码如下(示例):
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
int main(int argc, char const *argv[])
{
int i = 0;
pid_t pid = fork();
if(pid) {
printf("我是父进程! 我的ID是:%d\n", getpid() );
} else{
printf("我是子进程! 我的ID是:%d\n", getpid() );
//execl("./demo1", "demo1", NULL);
char *const argv[] = {"demo1", NULL};
execv("./demo1", argv);
}
return 0;
}
结果如图所示:
3.execp示例3
代码如下(示例):
将demo1.c文件复制一份名字为a.c
//execl("/bin/cp", “cp”, "demo1.c", "a.c", NULL);
execp("cp", "cp", "demo1.c", "a.c", NULL);
总结
① exec函数函数执行后进程的内存空间有何变化?
会被新的可执行文件重新初始化
②该函数执行结束后后面的语句是否能运行?
…
… execl("/bin/cp" , “cp” , “fork-1.c” , “a.c” , NULL );
…A
…B
代码AB 不会被执行, 因为内存已经被覆盖了