fork创建子进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支),子进程往往要调用一种exec函数以执行另一个程序。当进程调用一种exec函数时,该进程的用户空间代码和数据完全被新程序替换,从新程序的启动例程开始执行。调用exec并不创建新进程,所以调用exec前后该进程的id并未改变。
将当前进程的.text、.data替换为所要加载的程序的.text、.data,然后让进程从新的.text第一条指令开始执行,但进程ID不变,换核不换壳。
execlp
int execl(const char *path, const char *arg, ...);
加载一个进程,借助PATH环境变量
参数1:要加载的程序的名字。该函数需要配合PATH环境变量来使用,当PATH中所有目录搜索后没有参数1则出错返回。
该函数通常用来调用系统程序。如:ls、date、cp、cat等命令。
如execlp("ls", "xxx", "-l", "NULL");该函数相当于执行ls -l ,其中第二个参数相当于argv[0],无实际意义
execl
int execlp(const char *file, const char *arg, ...);
加载一个进程, 通过 路径+程序名 来加载。
如execl("/bin/ls", "xxx", "-l", "NULL");
也可以加载自己写的可执行程序