【Linux进程特别篇】深度理解辨识僵尸进程和孤儿进程
---------------------------------------------------------------------------------------------------------------------------------
每日鸡汤:每一份坚持都是成功的积累,只要相信自己,总会遇到惊喜。
-------------------------------------------------------------------------------------------------------------------------------
目录
编辑
一:进程的状态
二:僵尸进程
2.1:僵尸进程的定义与特点
2.2:僵尸进程怎样产生的,如何避免出现僵尸进程?
三:孤儿进程
2.1:孤儿进程的定义与特点
2.2:孤儿进程怎样产生的,如何避免出现孤儿进程?
四:区分辨识僵尸进程和孤儿进程
4.1:僵尸进程和孤儿进程的实例源码
4.1.1:创建僵尸进程
4.1.2:创建孤儿进程
4.2:总结区别僵尸进程和孤儿进程
一:进程的状态
进程在操作系统中可以处于多种状态,这些状态反映了进程在生命周期中的不同阶段。通常,最基本的进程状态模型包括三种状态:就绪(Ready)、运行(Running)和阻塞(Blocked),有时也称为等待(Waiting),但是在Linux中还有一些其他的进程状态,比如暂停态,僵尸态,孤儿态等
即,僵尸进程和孤儿进程是Unix/Linux操作系统中两种特殊类型的进程状态。它们都涉及到父进程与子进程之间的关系 。
为了深度理解父子进程,了解僵尸进程和孤儿进程是学习道路上必不可少的一个阶段。
二:僵尸进程
2.1:僵尸进程的定义与特点
僵尸进程的定义:
僵尸进程是一个已经完成执行(即其所有代码都已运行完毕),但其父进程尚未读取其退出状态的进程。
僵尸进程的特点:
- 僵尸进程不再占用任何CPU资源或内存资源,但它仍然在系统进程表中占有一项,保留了一些信息(如进程ID、退出状态等)。
- 如果不及时处理僵尸进程,系统中的进程表会逐渐被填满,最终可能导致无法创建新的进程。
2.2:僵尸进程怎样产生的,如何避免出现僵尸进程?
僵尸进程由很多的危害,那么僵尸进程是如何产生的呢
当一个子进程终止时,它会向其父进程发送一个信号(通常是 SIGCHLD),通知父进程它的退出状态。如果父进程没有调用 wait() 或 waitpid() 来读取子进程的退出状态,子进程就会变成僵尸进程。
避免出现僵尸进程:
父进程尽快通过wait()或waitpid()来收集子进程的状态信息,这样内核就可以回收子进程的PCB。如果父进程不这样做,可以考虑发送信号给父进程强制其处理,或者重启父进程。
三:孤儿进程
2.1:孤儿进程的定义与特点
孤儿进程的定义:
如果一个进程的父进程在它之前终止了,而该进程自己仍然存活并运行着,这样的进程被称为孤儿进程。
孤儿进程的特点:
- 在现代Unix/Linux系统中,一旦某个进程成为孤儿进程,init进程(进程号为1)会自动收养这些孤儿进程。
- init进程会负责等待孤儿进程结束,并且清理它们的状态信息。
- 孤儿进程继续正常运行,直到它们自然终止。
2.2:孤儿进程怎样产生的,如何避免出现孤儿进程?
孤儿进程的产生:
- 父进程在子进程之前退出:当一个进程(父进程)创建了一个或多个子进程后,如果父进程在它的所有子进程之前终止了,那么这些子进程就变成了孤儿进程。这是因为每个进程都有一个父进程,而一旦父进程不再存在,子进程就会失去它们的父进程。
- 父进程被强制终止:有时候,父进程可能因为某种原因被系统管理员或者通过其他程序(如使用kill命令)强制终止。如果此时有活动的子进程,那么这些子进程也会变成孤儿进程。
- 父进程崩溃:如果父进程由于编程错误或者其他问题而崩溃,同样会导致其子进程成为孤儿进程。
- 父进程主动放弃子进程:在某些情况下,父进程可能会调用特定的函数(例如prctl(PR_SET_PDEATHSIG, SIGKILL))来设置自己死亡时向子进程发送信号,从而让子进程知道自己的父进程已经不存在,并采取相应的行动。但如果不这样做,子进程仍会成为孤儿
避免出现孤儿进程:
通常不需要特别处理孤儿进程,因为init进程会接管它们。但如果希望避免产生孤儿进程,可以在编写程序时确保父进程妥善地管理其子进程的生命周期,例如使用信号处理器来捕获父进程的退出信号并在退出前清理子进程。
四:区分辨识僵尸进程和孤儿进程
4.1:僵尸进程和孤儿进程的实例源码
4.1.1:创建僵尸进程
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>int main()
{pid_t id = fork();if(id == 0){//子进程int cnt = 5;while(cnt){printf("我是子进程,pid: %d, ppid: %d, cnt: %d\n",getpid(),getppid(),cnt);cnt--;sleep(1);}exit(0);}else{while(1){printf("我是父进程,pid: %d, ppid: %d\n",getpid(),getppid());sleep(1);}}return 0;
}
父进程还没有运行完,而子进程运行完了,子进程的资源没有被父进程回收。
查看实例情况:

4.1.2:创建孤儿进程
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>int main()
{pid_t id = fork();if(id == 0){//子进程int cnt = 500;while(cnt){printf("我是子进程,pid: %d, ppid: %d, cnt: %d\n",getpid(),getppid(),cnt);cnt--;sleep(1);}exit(0);}else{int cnt1 = 5;while(cnt1--){printf("我是父进程,pid: %d, ppid: %d, cnt1 = %d\n",getpid(),getppid(), cnt1);sleep(1);}}return 0;
}
当父进程运行完毕回收,而子进程却还正在运行。此时该子进程就被称为孤儿进程。因为孤儿进程的父进程已经被回收了,所以为了保障到时候该子进程运行结束有父进程回收他的资源(不让他成为僵尸进程),操作系统(init进程,进程号为1)会 “收养” 该子进程,所以该子进程的父进程就是init进程,其父进程号为1,那么该子进程就被称为孤儿进程。
查看实例情况:

4.2:总结区别僵尸进程和孤儿进程
子进程退出,父进程还在运行,但父进程没有读取子进程状态,子进程进入僵尸状态,子进程就称之为“僵尸进程”
父进程先退出,子进程还在运行,子进程被操作系统“领养”,子进程就称之为“孤儿进程”
相关文章:
【Linux进程特别篇】深度理解辨识僵尸进程和孤儿进程
--------------------------------------------------------------------------------------------------------------------------------- 每日鸡汤:每一份坚持都是成功的积累,只要相信自己,总会遇到惊喜。 -----------------------------…...
喜报|超维机器人荣获昇腾AI创新大赛铜奖
近日,在备受瞩目的昇腾AI创新大赛中,超维机器人凭借扎实的技术实力和创新产品,荣获大赛铜奖。这一荣誉不仅展现了超维机器人在智能巡检领域的技术创新与突破,也标志着超维机器人的智能巡检解决方案在人工智能领域获得了广泛认可&a…...
从五种架构风格推导出HTTP的REST架构
在分布式系统中,架构风格(Architectural Style)决定了系统组件如何交互、通信、存储和管理数据。每种架构风格都有其独特的特性和适用场景。本文将从五种典型的架构风格出发,逐步探讨它们如何影响了REST(Representational State Transfer,表述性状态转移)架构风格的设计…...
vue-h5:在h5中实现相机拍照加上身份证人相框和国徽框
方案1:排出来照片太糊了,效果不好 1.基础功能 参考: https://blog.csdn.net/weixin_45148022/article/details/135696629 https://juejin.cn/post/7327353533618978842?searchId20241101133433B2BB37A081FD6A02DA60 https://www.freesio…...
免费HTML模板和CSS样式网站汇总
HTML模板:(注意版权,部分不可商用) 1、Tooplate,免费HTML模板下载 Download 60 Free HTML Templates for your websitesDownload 60 free HTML website templates or responsive Bootstrap templates instantly from T…...
Mac打开time machine(时间机器)备份特殊文件
Mac 打开time machine(时间机器)备份特殊文件 设置“时间机器”的作用具体操作办法 前言:今天在使用Nas同步文件时发现有部分重要文件没有同步,为了省事手动拖拽复制文件,导致其中一份非常重要的文件丢失,尝…...
Qt 学习第十六天:文件和事件
一、创建widget对象(文件) 二、设计ui界面 放一个label标签上去,设置成box就可以显示边框了 三、新建Mylabel类 四、提升ui界面的label标签为Mylabel 五、修改mylabel.h,mylabel.cpp #ifndef MYLABEL_H #define MYLABEL_H#incl…...
nvm 切换 Node.js 版本
nvm 切换 Node.js 版本 0. nvm 安装1. 查看装了哪些 Node.js 版本2. 安装 Node.js 版本安装最新稳定版本.安装个18 3. 切换 Node.js 版本4. 设置默认 Node.js 版本5. 卸载 Node.js 版本6.与项目的配合使用参考资料 0. nvm 安装 安装教程就不写了,直接看别人的。 脚…...
AI绘图最强软件stable diffusion,一文带你迅速了解!
有需要stable diffusion整合包可以扫描下方,免费获取 01 — 什么是 SD Stable Difusion(简称 SD) 其三种概念。 1.用来指代稳定扩散(Stable Diffusion) 技术,如 Midjourney是基于Stable Difusion技术实现的就是指它运用了 Stable Diffusion 的技术原理。 …...
VMware重磅官宣!Workstation和Fusion彻底全部免费:支持商用
VMware 官网宣布:VMware Workstation Pro: Now Available Free for Personal Use 别问,问就是正版用户!!! VMware宣布,其桌面虚拟化产品VMware Workstation和VMware Fusion将对所有用户彻底免费࿰…...
CCS 学习记录
1.导入项目 在CCS菜单中选择Project->Import Existing CCS Eclipse Project,点击Browse找到CCS workspace所在文件夹,点击OK,CCS会自动将所选文件夹及其子文件夹下所有的CCS Projects列出。从列表中找到所要导入的项目文件夹,…...
241112.学习日志——[CSDIY] Cpp零基础速成 [01]
CSDIY:这是一个非科班学生的努力之路,从今天开始这个系列会长期更新,(最好做到日更),我会慢慢把自己目前对CS的努力逐一上传,帮助那些和我一样有着梦想的玩家取得胜利!!&…...
94.【C语言】数据结构之双向链表的初始化,尾插,打印和尾删
目录 1.双向链表 2.结构体的定义 3.示意图 3.代码示例 1.双向链表的尾插 示意图 代码 main.c List.h List.c 详细分析代码的执行过程 双向链表的初始化 2.双向链表的打印 代码 3.双向链表的尾删 1.双向链表 以一种典型的双向链表为例:带头双向循环链表(带头:带…...
learn-F12 Performance(性能)前端性能分析(LCP,CLS,INP)
1.前言 在浏览器开发者工具(F12)中,本地指标(Local Metrics)包括LCP( Largest Contentful Paint)、CLS( Cumulative Layout Shift)和INP( Interaction to Nex…...
XCZU47DR-2FSVE1156
XCZU47DR-2FSVE1156 芯片概述 XCZU47DR-2FSVE1156 是一款由 Xilinx 公司生产的 Zynq UltraScale™ RFSoC 芯片。该芯片集成了多种高性能组件,包括四核 ARM Cortex-A53 MPCore™ 和双核 ARM Cortex™-R5,提供了强大的计算能力和灵活性。它还具备丰富的连…...
物联网低功耗广域网LoRa开发(一):LoRa物联网行业解决方案
一、LoRa的优势以及与其他无线通信技术对比 (一)LoRa的优势 1、164dB链路预算 、距离>15km 2、快速、灵活的基础设施易组网且投资成本较少 3、LoRa节点模块仅用于通讯电池寿命长达10年 4、免牌照的频段 网关/路由器建设和运营 、节点/终端成本低…...
【LeetCode】【算法】23. 合并K个升序链表
LeetCode 23. 合并K个升序链表 题目描述 给你一个链表数组,每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中,返回合并后的链表。 思路 思路:用小根堆解,很强 创建一个小根堆,排序规则为小根堆排序…...
python3的基本数据类型:Dictionary(字典)的创建
一. 简介 本文开始简单学习一下 python3中的一种基本数据类型:Dictionary(字典)。 字典(dictionary)是Python中另一个非常有用的内置数据类型。 二. python3的基本数据类型:Dictionary(字典&…...
【C++】string模拟实现
各位读者老爷好,俺最近在学习string的一些知识。为了更好的了解string的结构,俺模拟实现了一个丐版string,有兴趣的老爷不妨垂阅!!! 目录 1.string类的定义 2.模拟实现成员函数接口 2.1.constructor&am…...
Springboot 使用EasyExcel导出含图片并设置样式的Excel文件
Springboot 使用EasyExcel导出含图片并设置样式的Excel文件 Excel导出系列目录:★★★★尤其注意:引入依赖创建导出模板类逻辑处理controllerservice 导出效果总结 Excel导出系列目录: 【Springboot 使用EasyExcel导出Excel文件】 【Springb…...
IDEA运行Tomcat出现乱码问题解决汇总
最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…...
微信小程序之bind和catch
这两个呢,都是绑定事件用的,具体使用有些小区别。 官方文档: 事件冒泡处理不同 bind:绑定的事件会向上冒泡,即触发当前组件的事件后,还会继续触发父组件的相同事件。例如,有一个子视图绑定了b…...
vscode(仍待补充)
写于2025 6.9 主包将加入vscode这个更权威的圈子 vscode的基本使用 侧边栏 vscode还能连接ssh? debug时使用的launch文件 1.task.json {"tasks": [{"type": "cppbuild","label": "C/C: gcc.exe 生成活动文件"…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...
EtherNet/IP转DeviceNet协议网关详解
一,设备主要功能 疆鸿智能JH-DVN-EIP本产品是自主研发的一款EtherNet/IP从站功能的通讯网关。该产品主要功能是连接DeviceNet总线和EtherNet/IP网络,本网关连接到EtherNet/IP总线中做为从站使用,连接到DeviceNet总线中做为从站使用。 在自动…...
Android第十三次面试总结(四大 组件基础)
Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成,用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机: onCreate() 调用时机:Activity 首次创建时调用。…...
Xen Server服务器释放磁盘空间
disk.sh #!/bin/bashcd /run/sr-mount/e54f0646-ae11-0457-b64f-eba4673b824c # 全部虚拟机物理磁盘文件存储 a$(ls -l | awk {print $NF} | cut -d. -f1) # 使用中的虚拟机物理磁盘文件 b$(xe vm-disk-list --multiple | grep uuid | awk {print $NF})printf "%s\n"…...
【VLNs篇】07:NavRL—在动态环境中学习安全飞行
项目内容论文标题NavRL: 在动态环境中学习安全飞行 (NavRL: Learning Safe Flight in Dynamic Environments)核心问题解决无人机在包含静态和动态障碍物的复杂环境中进行安全、高效自主导航的挑战,克服传统方法和现有强化学习方法的局限性。核心算法基于近端策略优化…...
AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别
【导读】 野生动物监测在理解和保护生态系统中发挥着至关重要的作用。然而,传统的野生动物观察方法往往耗时耗力、成本高昂且范围有限。无人机的出现为野生动物监测提供了有前景的替代方案,能够实现大范围覆盖并远程采集数据。尽管具备这些优势…...

