Linux_exec

概念
当进程调用exec函数,该进程执行的程序完全替换成新程序,从main开始执行,进程前后ID不变,exec只替换当前进程的正文段、数据段、堆段和栈段。

7个exec函数

#include 
int execl(const char *pathname, const char *arg0, .../* (char *)0 */ );
int execv(const char *pathname, char *const argv[]);
int execle(const char *pathname, const char *arg0, ...
            /* (char *)0, char *const envp[] */ );
int execve(const char *pathname, char *const argv[], char *const envp[]);
int execlp(const char *filename, char *const arg0, ... /* (char*)0 */ );
int execvp(const char *filename, char *const argv[]);
int fexecve(int fd, char *const argv[], char *const envp[]);
                //7个函数返回值,若出错返回-1;若成功不返回

三个区别

区别一

前4个函数取路径名作为参数,后两个函数取文件名作为参数,最后一个取文件描述符作为参数。
如果filename中包含/,则就将其视作路径名
否则按PATH环境变量,在它所指定的各目录中搜寻可执行文件
PATH=/bin : /usr/bin : /usr/local/bin : .
如果execlp或execvp使用路径前缀中的一个找到可执行文件,但该文件不是编辑器产生的机器可执行文件,则就认为该文件是一个shell脚本,于是试着调用/bin/sh,并以该filename最为shell输入。

区别二

与参数表传递有关
execl、execlp和execle每个命令行参数都是单独的参数,最后以空指针结尾。
execv、execvp、execve和fexecve,应先构造一个指向参数的指针数组。

区别三

以e结尾的3个函数,可以传递一个指向环境字符串指针数组的指针。
其他4个函数则使用调用进程中的environ变量为新程序复制现有的环境

关系
这7个函数只有execve是内核的系统调用,另外6个都是库函数,最后都要调用该系统调用。
execlp —建立argv—> execvp —尝试每个PATH—> execv
execl —建立argv—> execv —使用execve—> execve
execle —建立argv—> execve
fexecve —build path from /proc/self/fdalias—> execve

你可能感兴趣的:(Linux)