Linux进程等待

Linux进程等待

一.什么是进程等待

通过系统调用wait和waitpid,来进行对子进程进行状态检测与回收功能。

二.为什么要有进程等待

1。之前讲过,子进程退出,父进程如果不管不顾,就可能造成'僵尸进程'的问题,进而造成内存泄漏。

2.另外,进程一旦变成僵尸状态,那就刀枪不入,"杀人不眨眼"的kill -9 也无能力,因为谁也没有办法杀死一个已经死去的进程。

3.最后,父进程派给子进程的任务完成的如何,我们需要知道。如,子进程运行完成,结果对还是不对,或者是否正常退出。

4.父进程通过进程等待的方式,回收子进程资源,获取子进程退出信息。

三.怎么进行进程调用

1.僵尸进程问题

一个例子


这样子进程就变成了僵尸进程,现在来验证一下wait能否回收。

到目前为止,进程等待是必须的,不然就会进入僵尸进程。当有多个子进程时,wait等待任意一个子进程退出。所以如果有多个子进程又该如何退出呢?

第二个例子

所以如果退出多个子进程需要使用多个wait。如果子进程不退出,父进程默认在wait的时候调用系统调用的时候,也就不返回,默认叫做阻塞状态。

2.waitpid

3.获取进程退出状态

使用wait/waitpid的status参数

一旦子进程退出,操作系统就会将退出信息拷贝到status中,然后就可以将其带出来。接下来令子进程退出码为1,看看status会不会将1带出来。

为什么status会返回256呢?

这是因为status要当成一个位图来看。

由于子进程退出为1,而第8为到15为代表退出状态,所以转化就成了256.

相关推荐
sinat_384241092 小时前
使用 npm 安装 Electron 作为开发依赖
服务器
朝九晚五ฺ2 小时前
【Linux探索学习】第十四弹——进程优先级:深入理解操作系统中的进程优先级
linux·运维·学习
自由的dream2 小时前
Linux的桌面
linux
xiaozhiwise3 小时前
Makefile 之 自动化变量
linux
Kkooe3 小时前
GitLab|数据迁移
运维·服务器·git
久醉不在酒4 小时前
MySQL数据库运维及集群搭建
运维·数据库·mysql
意疏5 小时前
【Linux 篇】Docker 的容器之海与镜像之岛:于 Linux 系统内探索容器化的奇妙航行
linux·docker
虚拟网络工程师5 小时前
【网络系统管理】Centos7——配置主从mariadb服务器案例(下半部分)
运维·服务器·网络·数据库·mariadb
BLEACH-heiqiyihu5 小时前
RedHat7—Linux中kickstart自动安装脚本制作
linux·运维·服务器