博客
关于我
Linux:程序替换
阅读量:324 次
发布时间:2019-03-04

本文共 2172 字,大约阅读时间需要 7 分钟。

Linux程序替换

程序替换在Linux系统中是一种常见的操作方式,通过调用exec函数族,可以在现有进程中替换为新的程序。这种方式能够在不创建新进程的情况下,立即运行新的程序。

程序替换的核心原理是利用fork创建子进程后,调用exec函数将子进程的代码和数据替换为新的程序。虽然fork会创建新的进程,但调用exec后进程ID并不会改变,继续使用原有的进程空间。这使得程序替换成为在不影响现有进程情况下更换程序的有效手段。

替换方法

在Linux系统中,程序替换主要通过以下六种exec函数来实现:

#include 
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 列表形式 不是
execlp 列表形式
execle 列表形式 不是 不是(需要自己组装环境变量)
execv 数组形式 不是
execvp 数组形式
execve 数组形式 不是 不是(需要自己组装环境变量)

注意:这些函数调用成功后,会立即执行新的程序,不会返回任何值;如果调用失败,会返回-1。因此,在调用exec函数后,必须检查返回值是否为-1,否则可能导致程序无法正常退出。

函数规律

通过对这些exec函数的分析可以发现,主要有以下几个规律:

  • 参数格式的区别:execl和execlp接受列表形式的参数,而execv、execvp和execve接受数组形式的参数。
  • 路径的自动搜索:execlp会自动搜索PATH环境变量,找到程序的路径;而execl需要完全指定路径。
  • 环境变量的处理:execle和execve不使用当前进程的环境变量,需要自己组装环境变量;而其他函数会继承当前进程的环境变量。
  • 示例代码

    #include 
    #include
    #include
    int main() { pid_t pid = fork(); if (pid < 0) { perror("fork"); return -1; } else if (0 == pid) { char *const argv[] = {"ps", "-ef", NULL}; char *const envp[] = {"PATH=/bin:/usr/bin", "TERM=console", NULL}; if (execl("/bin/ps", "ps", "-ef", NULL) < 0) { perror("execl"); } if (execlp("ps", "ps", "-ef", NULL, envp) < 0) { perror("execlp"); } if (execle("ps", "ps", "-ef", NULL, envp) < 0) { perror("execle"); } if (execv("/bin/ps", argv) < 0) { perror("execv"); } if (execvp("ps", argv) < 0) { perror("execvp"); } if (execve("/bin/ps", argv, envp) < 0) { perror("execve"); } sleep(30); exit(0); } else { sleep(30); printf("子进程退出!\n"); while (1) { printf("正在打麻将!\n"); } }}

    在这个示例中,我们通过fork创建子进程,并在子进程中调用不同的exec函数来替换程序。每个函数都有不同的特点,例如execlp会自动搜索程序路径,而execve则需要自己组装环境变量。

    转载地址:http://xbmq.baihongyu.com/

    你可能感兴趣的文章
    NUMPY矢量化np.prod不能构造具有超过32个操作数的ufunc
    查看>>
    Numpy矩阵与通用函数
    查看>>
    numpy绘制热力图
    查看>>
    numpy转PIL 报错TypeError: Cannot handle this data type
    查看>>
    Numpy闯关100题,我闯了95关,你呢?
    查看>>
    nump模块
    查看>>
    Nutch + solr 这个配合不错哦
    查看>>
    NuttX 构建系统
    查看>>
    NutUI:京东风格的轻量级 Vue 组件库
    查看>>
    NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
    查看>>
    NutzWk 5.1.5 发布,Java 微服务分布式开发框架
    查看>>
    NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
    查看>>
    NUUO网络视频录像机 upload.php 任意文件上传漏洞复现
    查看>>
    Nuxt Time 使用指南
    查看>>
    NuxtJS 接口转发详解:Nitro 的用法与注意事项
    查看>>
    NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
    查看>>
    NVelocity标签使用详解
    查看>>
    NVelocity标签设置缓存的解决方案
    查看>>
    Nvidia Cudatoolkit 与 Conda Cudatoolkit
    查看>>
    NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
    查看>>