exec函数族
- 一般先创建一个子进程,再在子进程中调用exec函数族
- 会根据指定的文件名找到可执行文件,并用它来取代调用进程的内容,即在调用进程内部执行一个可执行文件
- exec函数族执行成功后不会返回,因为调用进程的实体,包括代码段、数据段和堆栈都已经被新的内容取代,只留下进程ID等表面上的信息,只要调用失败是会返回-1
- 如果在子进程中使用exec函数族,子进程后续代码都会被替换掉,都不会被执行
#include <unistd.h>
extern char **environ;
int execl(const char *pathname, const char *arg, ...);
参数:
path:需要指定的执行文件的绝对路径或名词
arg:字符串,是可执行文件的参数列表,参数最后以NULL结束
返回值:
只有调用失败才有返回值,返回-1,并且设置errno
调用成公没有返回值
int execlp(const char *file, const char *arg, ...);
会到环境变量中查找指定的可执行文件,如果找到了就执行,找不到就执行失败
参数:
file:需要执行的可执行文件的文件名
arg:字符串,是可执行文件的参数列表,参数最后以NULL结束
标签:可执行文件,调用,const,函数,exec,char,进程
From: https://www.cnblogs.com/xiaoqing-ing/p/17103327.html