Linux 僵死进程

fork复制进程之后,会产生一个进程叫做子进程,被复制的进程就是父进程。不管父进程先结束,还是子进程先结束,对另外一个进程完全没有影响,父进程和子进程是两个不同的进程。

一、孤儿进程

现在有以下代码:

在这里插入图片描述

【注意】
上述代码中,调用getpid()输出当前进程的pid,调用getppid()输出当前进程的父进程的pid。

让子进程执行7次,父进程执行3次,编译并运行,结果如下:

在这里插入图片描述

分析:当父进程执行完3次之后,子进程的父进程结束,子进程就变为了孤儿进程,孤儿进程会被系统中的inti(pid=1)收养,但是在目前有些系统中,也会被随机的其他进程收养。例如,上图中,父进程执行完3次之后,父进程结束,子进程就变为了孤儿进程,该孤儿进程的父进程的id就变成了1145,说明该孤儿进程的父进程变为了pid为1145的一个进程。

二、僵死进程

僵死进程:子进程先与父进程结束,父进程没有获取子进程的退出码,子进程就变成了僵死进程。

有以下代码:

在这里插入图片描述

编译以上代码,并在后台运行,运行的时候通过ps查看进程信息,结果如下:

在这里插入图片描述

分析:

由结果可以看出当子进程结束之后,通过ps查看进程信息的时候还是可以看到子进程的信息,只不过子进程后边加了一个注释<defunct>,表示该子进程变成了僵死进程,僵死进程就是表示代码已经结束了,是已经结束的进程,这个进程在以后再也不会执行了。按道理子进程在结束了之后不应该还能看到这个进程,也就是说这个子进程本来应该已经死掉了,但是我们还能看到它,这是不合理的。

我们之所以还能看到这个子进程(僵死进程),是因为子进程比父进程先结束,父进程没有获取子进程的退出码,该子进程就变成了僵死进程。

所谓退出码是存放到PCB中的,当子进程结束之后如果父进程没有获取子进程的退出码,那么子进程的PCB就不会消失,会一直存在,所以在子进程结束之后再查看进程信息的时候就还能看到子进程的信息,但是这个子进程已经是僵死进程了。如果一个进程不断产生子进程,子进程结束后也没有获取子进程的退出码,那么这些子进程就会变成僵死进程僵死进程就会越来越多,那么内核空间的内存就会被逐渐耗光,而且僵死进程会占用着PID不释放,那么这个PID就无法被复用,软件层面的资源也被占着。

三、处理僵死进程

父进程获取子进程的退出码,僵死进程就会消失。这一步要通过父进程调用wait()来完成。wait()可以获取子进程的退出码,处理僵死进程。

代码如下:

在这里插入图片描述

运行结果如下:

①在前台运行:

在这里插入图片描述
根据运行结果可以看出,一开始只有子进程在执行,因为父进程中执行了wait,子进程执行的时候由于wait阻塞住了父进程,子进程执行结束之后,父进程才开始执行,也就是说父进程在等待子进程结束。

代码中可以看到无论父进程还是子进程退出码的值都为3,但是运行结果中val的值并不是3,而是768,这是因为int型变量占4个字节,将3换算为二进制数之后为11,这个11并不会存在第一个字节的起始位置,而是会在4个字节中的任意位置。如下图所示,把768转换为二进制数为0011 0000 0000:

在这里插入图片描述

将val的值向右移动8个位,将代码中的printf("val=%d\n",val);改为printf("val=%d\n",val>>8);之后,再编译运行,val的值的结果就是3了,如下图所示:

在这里插入图片描述

②在后台运行

运行结果:

在这里插入图片描述

作为父进程要关注有自己产生的子进程,不能让它们变为僵死进程。

如果父进程比子进程先结束,父进程没有通过wait处理结束的子进程,子进程变为了僵死进程,等到父进程结束以后,此时不管子进程活着还是死掉了,就会给子进程重新找一个父进程,让这个另外的进程来收养子进程,另外的进程来收养子进程的意义就在于这个收养子进程的父进程就会接管这个子进程,然后执行wait获取该子进程的退出码,那么即便收养的子进程已经结束变成了僵死进程,通过收养它的父进程来执行wait,这个僵死进程就消失了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/69296.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大数据Flink(六十):Flink 数据流和分层 API介绍

文章目录 Flink 数据流和分层 API介绍 一、​​​​​​​​​​​​​​Flink 数据流

【Vue-Router】路由元信息

路由元信息&#xff08;Route Meta Information&#xff09;是在路由配置中为每个路由定义的一组自定义数据。这些数据可以包含任何你希望在路由中传递和使用的信息&#xff0c;比如权限、页面标题、布局设置等。Vue Router 允许你在路由配置中定义元信息&#xff0c;然后在组件…

ComponentOne Studio ASP.NET MVC Crack

ComponentOne Studio ASP.NET MVC Crack FlexReport增强功能 添加了对在Microsoft Windows上部署Microsoft Azure的支持。 添加了对显示嵌入字体的支持。 .NET标准版的经典C1PDF(Beta版) GrapeCity的经典C1Pdf库现在提供了基于Microsoft.NET标准的版本。在任何.NET应用程序(包括…

【论文阅读】DEPCOMM:用于攻击调查的系统审核日志的图摘要(SP-2022)

Xu Z, Fang P, Liu C, et al. Depcomm: Graph summarization on system audit logs for attack investigation[C]//2022 IEEE Symposium on Security and Privacy (SP). IEEE, 2022: 540-557. 1 摘要 ​ 提出了 DEPCOMM&#xff0c;这是一种图摘要方法&#xff0c;通过将大图划…

Canal+Kafka实现Mysql数据同步

Canal介绍 canal [kənl]&#xff0c;译意为水道/管道/沟渠&#xff0c;主要用途是基于 MySQL 数据库增量日志解析&#xff0c;提供增量数据订阅和消费 canal可以用来监控数据库数据的变化&#xff0c;从而获得新增数据&#xff0c;或者修改的数据。 canal是应阿里巴巴存在杭…

基于VUE3+Layui从头搭建通用后台管理系统(前端篇)九:自定义组件封装下

一、本章内容 续上一张,本章实现一些自定义组件的封装,包括文件上传组件封装、级联选择组件封装、富文本组件封装等。 1. 详细课程地址: 待发布 2. 源码下载地址: 待发布 二、界面预览 三、开发视频 基于VUE3+Layui从头搭建通用后台管

PyTorch从零开始实现ResNet

文章目录 代码实现参考 代码实现 本文实现 ResNet原论文 Deep Residual Learning for Image Recognition 中的50层&#xff0c;101层和152层残差连接。 代码中使用基础残差块这个概念&#xff0c;这里的基础残差块指的是上图中红色矩形圈出的内容&#xff1a;从上到下分别使用…

插入、希尔、归并、快速排序(java实现)

目录 插入排序 希尔排序 归并排序 快速排序 插入排序 排序原理&#xff1a; 1.把所有元素分为两组&#xff0c;第一组是有序已经排好的&#xff0c;第二组是乱序未排序。 2.将未排序一组的第一个元素作为插入元素&#xff0c;倒序与有序组比较。 3.在有序组中找到比插入…

docker实现Nginx

文章目录 1.docker 安装2.docker环境实现Nginx 1.docker 安装 1.使用环境为红帽8.1,添加源 yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo2.安装 yum install docker-ce docker-ce-cli containerd.io显示出错 Docker C…

机器学习深度学习——seq2seq实现机器翻译(数据集处理)

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位即将上大四&#xff0c;正专攻机器学习的保研er &#x1f30c;上期文章&#xff1a;机器学习&&深度学习——从编码器-解码器架构到seq2seq&#xff08;机器翻译&#xff09; &#x1f4da;订阅专栏&#xff1a;机…

一波七折之寻找遗失的容器ip

最近业务有个需求&#xff0c;需要在宿主机上获取容器ip。获取ip这就不是个事&#xff0c;平凡而普通。 常用手段获取ip 常用的命令ifconfig, ip等等首先被pass&#xff0c;因为宿主机环境未知&#xff0c;这些命令可能没有。 那么只能从系统api着手。getifaddrs可以获取网卡…

WSL2 Ubuntu子系统安装cuda+cudnn+torch

文章目录 前言一、安装cudncudnn安装pytorch 前言 确保Windows系统版本高于windows10 21H2或Windows11&#xff0c;然后在Windows中将显卡驱动升级到最新即可&#xff0c;WSL2已支持对显卡的直接调用。 一、安装cudncudnn 配置cuda环境&#xff0c;WSL下的Ubuntu子系统的cu…