• linux 中的 exec 函数族


    fork创建子进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支),子进程往往要调用一种exec函数以执行另一个程序。当进程调用一种exec函数时,该进程的用户空间代码和数据完全被新程序替换,从新程序的启动例程开始执行。调用exec并不创建新进程,所以调用exec前后该进程的id并未改变。

    将当前进程的.text、.data替换为所要加载的程序的.text、.data,然后让进程从新的.text第一条指令开始执行,但进程ID不变,换核不换壳。

    其实有六种以exec开头的函数,统称exec函数:

    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 execve(const char *path, char *const argv[], char *const envp[]);

    execl函数

    加载一个进程, 通过 路径+程序名 来加载。

    #include <stdio.h>
    #include <unistd.h>
    
    int main()
    {
            printf("start:
    ");
            pid_t pid = fork();
            if(pid == 0)
            {
                    printf("child process:
    ");
                    //excel(程序路径,描述,参数,参数完结标记)
                    execl("/bin/ls", "ls", "-l", NULL);
            }
            else
            {
                    printf("parent process!
    ");
            }
            printf("stop!
    ");
            return 0;
    }
    View Code

    execlp函数

    加载一个进程,借助PATH环境变量 

    execlp("ls", "ls", "-l", NULL);

    exec函数族一般规律

    exec函数一旦调用成功即执行新的程序,不返回。只有失败才返回,错误值-1。所以通常我们直接在exec函数调用后直接调用perror()和exit(),无需if判断。

    l (list)                         命令行参数列表

    p (path)                     搜素file时使用path变量

    v (vector)                  使用命令行参数数组

    e (environment)      使用环境变量数组,不使用进程原有的环境变量,设置新加载程序运行的环境变量

    事实上,只有execve是真正的系统调用,其它五个函数最终都调用execve,所以execve在man手册第2节,其它函数在man手册第3节。这些函数之间的关系如下图所示。

  • 相关阅读:
    ssh 的参数 -o + 检查是否是无密码访问
    Linux下SVN服务器同时支持Apache的http和svnserve独立服务器两种模式且使用相同的访问权限账号
    Linux 下jJKD,Tomcat部署
    [转]深入理解Java的接口和抽象类
    Java 培训笔记
    十三、MySQL性能优化
    十二、MySQL用户管理
    十一、MySQL触发器
    十、MySQL视图
    九、MySQL存储过程和函数
  • 原文地址:https://www.cnblogs.com/xumaomao/p/13057446.html
Copyright © 2020-2023  润新知