[Linux 高并发服务器] exec函数族
2021/10/13 7:14:09
本文主要是介绍[Linux 高并发服务器] exec函数族,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
[Linux 高并发服务器] exec函数族
exec函数族
exec 函数族的作用是根据指定的文件名找到可执行文件,并用它来取代调用进程的内容,换句话说,就是在调用进程内部执行一个可执行文件
exec 函数族的函数执行成功后不会返回,因为调用进程的实体,包括代码段,数据段和堆栈等都已经被新的内容取代,只留下进程 ID 等一些表面上的信息仍保持原样,只有调用失败了,它们才会返回 -1,从原程序的调用点接着往下执行。
一般我们创建一个子进程,然后在子进程中使用exec函数族。
虚拟地址空间视角
执行exec函数族后a.out的程序替换掉用户区数据
7个函数
其中前6个为标准C库的函数,最后1个为Linux系统函数,前6个基于最后一个进行封装,前两个比较常用。
execl
/* #include <unistd.h> int execl(const char *path, const char *arg, ...); - 参数: - path:需要指定的执行的文件的路径或者名称 a.out /home/nowcoder/a.out 推荐使用绝对路径 ./a.out hello world - arg:是执行可执行文件所需要的参数列表 第一个参数一般没有什么作用,为了方便,一般写的是执行的程序的名称 从第二个参数开始往后,就是程序执行所需要的的参数列表。 参数最后需要以NULL结束(哨兵) - 返回值: 只有当调用失败,才会有返回值,返回-1,并且设置errno 如果调用成功,没有返回值。 */ #include <unistd.h> #include <stdio.h> int main() { // 创建一个子进程,在子进程中执行exec函数族中的函数 pid_t pid = fork(); if(pid > 0) { // 父进程 printf("i am parent process, pid : %d\n",getpid()); sleep(1); }else if(pid == 0) { // 子进程 // execl("hello","hello",NULL); execl("/bin/ps", "ps", "aux", NULL); perror("execl"); printf("i am child process, pid : %d\n", getpid()); } for(int i = 0; i < 3; i++) { printf("i = %d, pid = %d\n", i, getpid()); } return 0; }
执行结果如下(两张拼着看,ps输出太长了)
因为子进程调用了execl
函数,所以用户区被可执行文件的数据替换掉,原来的代码也就没有了,所以子进程不会执行下面这些代码
printf("i am child process, pid : %d\n", getpid()); for(int i = 0; i < 3; i++) { printf("i = %d, pid = %d\n", i, getpid()); }
execlp
根据函数名从环境变量中找可执行程序
/* #include <unistd.h> int execlp(const char *file, const char *arg, ... ); - 会到环境变量中查找指定的可执行文件,如果找到了就执行,找不到就执行不成功。 - 参数: - file:需要执行的可执行文件的文件名 a.out ps - arg:是执行可执行文件所需要的参数列表 第一个参数一般没有什么作用,为了方便,一般写的是执行的程序的名称 从第二个参数开始往后,就是程序执行所需要的的参数列表。 参数最后需要以NULL结束(哨兵) - 返回值: 只有当调用失败,才会有返回值,返回-1,并且设置errno 如果调用成功,没有返回值。 int execv(const char *path, char *const argv[]); argv是需要的参数的一个字符串数组 char * argv[] = {"ps", "aux", NULL}; execv("/bin/ps", argv); int execve(const char *filename, char *const argv[], char *const envp[]); char * envp[] = {"/home/nowcoder", "/home/bbb", "/home/aaa"}; */ #include <unistd.h> #include <stdio.h> int main() { // 创建一个子进程,在子进程中执行exec函数族中的函数 pid_t pid = fork(); if(pid > 0) { // 父进程 printf("i am parent process, pid : %d\n",getpid()); sleep(1); }else if(pid == 0) { // 子进程 execlp("ps", "ps", "aux", NULL); printf("i am child process, pid : %d\n", getpid()); } for(int i = 0; i < 3; i++) { printf("i = %d, pid = %d\n", i, getpid()); } return 0; }
其他几个函数可以根据末尾字母含义或者查询man手册了解使用方法
这篇关于[Linux 高并发服务器] exec函数族的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-12如何创建可引导的 ESXi USB 安装介质 (macOS, Linux, Windows)
- 2024-11-08linux的 vi编辑器中搜索关键字有哪些常用的命令和技巧?-icode9专业技术文章分享
- 2024-11-08在 Linux 的 vi 或 vim 编辑器中什么命令可以直接跳到文件的结尾?-icode9专业技术文章分享
- 2024-10-22原生鸿蒙操作系统HarmonyOS NEXT(HarmonyOS 5)正式发布
- 2024-10-18操作系统入门教程:新手必看的基本操作指南
- 2024-10-18初学者必看:操作系统入门全攻略
- 2024-10-17操作系统入门教程:轻松掌握操作系统基础知识
- 2024-09-11Linux部署Scrapy学习:入门级指南
- 2024-09-11Linux部署Scrapy:入门级指南
- 2024-08-21【Linux】分区向左扩容的方法