exec

exec

    • 可加载可执行文件(ELF)或具有X权限的脚本
    • exec并不创建新进程,调用exec前后该进程id并未改变。
    • 进程调用exec函数以执行另一个程序,当前进程的用户空间代码和数据完全被新程序替代,从新程序启动例程开始执行。

#include <unistd.h>

extern char **environ;

int execl(const char *path, const char *arg, ...);

int execlp(const char *file, const char *arg, ...);

int execle(const char *path, const char *arg, ..., char * const envp[]);

int execv(const char *path, char *const argv[]);

int execvp(const char *file, char *const argv[]);

int execvpe(const char *file, char *const argv[], char *const envp[]);

  • 不带字母p(标识path)的exec函数,第一参数必须是程序相对路径或绝对路径,eg. /bin/ls 或./a.out,而不能是ls或a.out。故其参数名为path。
  • 对于带p的函数,包含/表路径名;无路径在环境变量PATH列表中搜索程序。故其参数为file(可执行程序名)。
  • 按照惯例,argv或arg的第一参数(arg0, argv[0])为程序名,最后一参数为NULL。argv或arg包含程序名,是所有的命令行参数,如同main参数(argv[0]为程序名)。
  • l的函数要求将新程序的每个命令行参数都当作一个参数传给它,参数个数可变。list
  • v的函数要求参数以array数组形式传递。
  • e代表环境变量,最后一个参数为NULL,代表程序新的环境变量。不带e,表示新进程的环境变量来自原进程的外部变量environ。

失败-1,成功不返回。

execl("ls", "ls", "-al", NULL); 错误

execl("/bin/ls", "ls", "-al", NULL); 正确

char *exec_argv[3] = {"ls", "-al", NULL};
execvp("ls", exec_argv); 正确

execv("ls", exec_argv); 错误

示例

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/wait.h>

int main(void)
{
    int pid;
    char *cmd[] = {"ls", "-al", NULL};

    pid = fork();
    if(pid == 0){ 
        execvp(cmd[0], cmd);
        printf("Can't exex ls
");
        exit(-1);
    }   

    if(pid < 0){ 
        printf("Can't fork
");
        exit(-1);
    } else {
        pid = waitpid(pid, NULL, 0); 
        printf("%d exit
", pid);
    }   
    
    return 0;
}

 

原文地址:https://www.cnblogs.com/embedded-linux/p/5011282.html