目录进程程序替换替换原理替换函数替换函数名称助记进程程序替换 替换原理 使用fork创建子进程后执行的是和父进程相同的程序,但是那样并没有多大的意义,子进程往往会“程序替
使用fork创建子进程后执行的是和父进程相同的程序,但是那样并没有多大的意义,子进程往往会“程序替换” 去执行另一个程序。程序替换的特点就是:不创建新的进程,仅仅替换掉该进程的代码和数据。
#include <unistd.h>
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[]);
//path表示全路径,file表示文件名
//可变参数列表,在终端上怎么写的,就怎么传参
注意:可变参数列表的参数个数是未确定的,如果你确定好自己的参数个数了,则以NULL结尾,表示就传这么多个参数了
假设程序替换成ls
execl("/usr/bin/ls", "ls", "-l", "-a", NULL)
使用execl
据个例子
#include <stdio.h>
#include <unistd.h>
#include <sys/wait.h>
#include <sys/types.h>
#include <stdlib.h>
int main(void)
{
if(fork() == 0)
{
//child
printf("i am child process:%d\n",getpid());
execl("/usr/bin/ls", "ls", "-l", NULL); //可变参数列表以NULL结尾,表示参数就是这么多
}
waitpid(-1, NULL, 0); //等待子进程
printf("123\n");
printf("1234\n");
printf("12345\n");
printf("123456\n");
printf("1234567\n");
return 0;
}
现象:
可以看到子进程只执行了ls -l
指令,而父进程还是执行自己的。
以上函数:
以上的函数都是exec系列的函数,并且都非常的相似,但是只要知道了其中的规律就能够牢记
如果后面的参数使用数组,也就是后缀为v,也需要在最后加上NULL
。
实际上,前五个函数execl、execlp、execle、execv、execvp是库函数,而execve是系统调用。前五个函数都是都系统调用execve的封装,只是封装的形式不同,这样可以应对不同的情况。
到此这篇关于C语言进程程序替换的实现详解的文章就介绍到这了,更多相关C语言进程内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: C语言进程程序替换的实现详解
本文链接: https://lsjlt.com/news/166233.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0