【Linux学习笔记34】进程操作核心API(exec组函数,wait/waitpid)

引言

系统创建多进程的目的就是让子进程能够帮助父进程完成更多事情,那通过上一篇笔记fork函数创建的子进程都拥有与父进程相同的程序,但是我们的目的是要让子进程完成一些其他事情,那么这篇笔记主要就是记录操作子进程运行其他代码的API。

exec组函数

head详细
功能在进程中加载新的程序文件或者脚本,覆盖原有代码,重新运行
头文件#include<unistd.h>
原型int execl(const char *path,const char *arg,…)
原型int execv(const char *path,const char *argv[])
原型int execle(const char *path,const char *arg,…,char *const envp[])
原型int execlp(const char *file,const char *arg,…)
原型int execvp(const char *file,char *const argv[])
原型int execvpe(const char *file,char *const argv[],char *const envp[])
参数path:即将被加载执行的ELF文件或者脚本的路径
参数file:即将被加载执行的ELF文件或者脚本的名字
参数arg:以列表方式罗列的ELF文件或者脚本的参数
参数argv:以数组方式组织的ELF文件或者脚本的参数
参数envp:用户自定义的环境变量数组
返回值成功:不返回
返回值失败:-1

运行原理:
在这里插入图片描述
execl代码实现:
在这里插入图片描述
在这里插入图片描述
当我们子进程需要运行的代码为大量代码的时候,就应该使用这种函数来覆盖原来的代码
运行结果:
在这里插入图片描述

wait函数与waitpid函数

head详细
功能等待子进程
头文件#include<>sys/wait.h
原型pid_t wait(int *stat_loc)
原型pid_t waitpid(pid_t pid,int *stat_loc,int options)
参数pid:小于-1:等待组ID的绝对值为pid的进程组中的任一子进程
参数pid:-1:等待任一子进程
参数pid:0:等待调用者所在的进程组中的任一子进程
参数pid:大于0:等待进程组ID为Pid的子进程
参数stat_loc:子进程退出状态
参数option:WCONTINUED:报告任一从暂停态出来且从未报告过的子进程状态
参数option:WNOHANG:非阻塞等待
参数option:WUNTRACED:报告任一当前处于暂停态且从未报告过的子进程状态
返回值Wait():成功:退出的子进程PID。失败:-1
返回值Waitpid():成功:状态发生改变的子进程PID。失败:-1

代码实现:父进程:
在这里插入图片描述
子进程:
在这里插入图片描述
运行结果:
在这里插入图片描述
但是奇怪的是,父进程并不是输出88而是22528
那么原因就是:

  • 退出状态中:退出值只是一部分,那么其实前面还有很大的一部分在记录其它信息:例如异常信号等

那么代码应该使用以下的宏来处理:
在这里插入图片描述
那么父进程运行的代码:
在这里插入图片描述
运行结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值