僵尸进程,孤儿进程,守护进程

2024-05-25 08:44
文章标签 进程 守护 僵尸 孤儿

本文主要是介绍僵尸进程,孤儿进程,守护进程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【一】僵尸进程

1.僵尸进程是指完成自己的任务之后,没有被父进程回收资源,占用系统资源,对计算机有害,应该避免
""" 所有的子进程在运行结束之后都会变成僵尸进程(死了没死透)还保留着pid和一些运行过程的中的记录便于主进程查看(短时间保存)这些信息会被主进程回收(僵尸彻底死了)"""
2.例子:当你关闭pycharm时,关于pycharm的进程都应该被关闭,有时候你会发现,有某几个 pycharm 进程任然在后台运行 --> 本来这部分资源应该被回收,结果因为还在运行,占用系统资源,这些没被回收的就是僵尸进程
3.解决办法:(1)UNIX提供了一种机制可以保证父进程可以在任意时刻获取子进程结束时的状态信息

【二】孤儿进程

1.孤儿进程是指父进程在子进程终止之前就结束了
2.例子: 在没有关闭共享屏幕的前提下直接退出腾讯会议,你的共享屏幕也会退出而不是一直挂在后台
3.解决办法:init进程 ,会接管这些没有父亲的孤儿,就把所有子线程杀死

【三】僵尸进程和孤儿进程谁的危害性更大?

僵尸进程的危害性更大
因为僵尸进程一直会持续存在在后台占用资源
孤儿进程因为主进程死亡后让然有init进程接管并销毁

【四】守护进程

 
1.守护即死活全部参与守护的对象对象死立刻死
2.例子:将子进程设置为守护进程:主进程结束 子进程立刻结束关机,各个进程服务都会关闭
子进程.daemon = True
代码例子

#主进程死,子进程必死,就像是给子进程加一个模式
# 要在进程开始start前加
from multiprocessing import Process
# 用加了守护和不加守护进行对比
def task1():print("我是进程1")
def task2():print("我是进程2")
if __name__ == '__main__':p1=Process(target=task1,)p2=Process(target=task2,)p1.daemon=Truep1.start()p2.start()p1.join()#加了join会让主进程阻塞住,让该子进程先执行print("我是主进程")"""结果:我是进程1我是主进程我是进程2
​"""
小练习
# 主进程代码运行完毕,守护进程就会结束
from multiprocessing import Process
from threading import Thread
import time
​
​
def foo():print(123)time.sleep(1)print("end123")
​
​
def bar():print(456)time.sleep(3)print("end456")
​
​
if __name__ == '__main__':p1 = Process(target=foo)p2 = Process(target=bar)
​p1.daemon = Truep1.start()p2.start()
​# 打印该行则主进程代码结束,则守护进程p1应该被终止,可能会有p1任务执行的打印信息123# 因为主进程打印main----时,p1也执行了,但是随即被终止print("main-------")# main-------# 456# end456

这篇关于僵尸进程,孤儿进程,守护进程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001024

相关文章

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

java 进程 返回值

实现 Callable 接口 与 Runnable 相比,Callable 可以有返回值,返回值通过 FutureTask 进行封装。 public class MyCallable implements Callable<Integer> {public Integer call() {return 123;}} public static void main(String[] args

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(

【多系统萎缩患者必看】✨维生素补充全攻略,守护你的健康每一天!

亲爱的朋友们,今天我们要聊一个既重要又容易被忽视的话题——‌多系统萎缩患者如何科学补充维生素‌!🌟 在这个快节奏的生活中,健康成为了我们最宝贵的财富,而对于多系统萎缩(MSA)的患者来说,合理的营养补充更是维护身体机能、提升生活质量的关键一步。👇 🌈 为什么多系统萎缩患者需要特别关注维生素? 多系统萎缩是一种罕见且复杂的神经系统疾病,它影响身体的多个系统,包括自主神经、锥体外系、小脑及锥

Golang进程权限调度包runtime

关于 runtime 包几个方法: Gosched:让当前线程让出 cpu 以让其它线程运行,它不会挂起当前线程,因此当前线程未来会继续执行GOMAXPROCS:设置最大的可同时使用的 CPU 核数Goexit:退出当前 goroutine(但是defer语句会照常执行)NumGoroutine:返回正在执行和排队的任务总数GOOS:目标操作系统NumCPU:返回当前系统的 CPU 核数量 p

如何保证android程序进程不到万不得已的情况下,不会被结束

最近,做一个调用系统自带相机的那么一个功能,遇到的坑,在此记录一下。 设备:红米note4 问题起因 因为自定义的相机,很难满足客户的所有需要,比如:自拍杆的支持,优化方面等等。这些方面自定义的相机都不比系统自带的好,因为有些系统都是商家定制的,难免会出现一个奇葩的问题。比如:你在这款手机上运行,无任何问题,然而你换一款手机后,问题就出现了。 比如:小米的红米系列,你启用系统自带拍照功能后

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位 一、背景二、定位问题三、解决方法 一、背景 flume系列之:定位flume没有关闭某个时间点生成的tmp文件的原因,并制定解决方案在博主上面这篇文章的基础上,在机器内存、cpu资源、flume agent资源都足够的情况下,flume agent又出现了tmp文件无法关闭的情况 二、

C++编程:ZeroMQ进程间(订阅-发布)通信配置优化

文章目录 0. 概述1. 发布者同步发送(pub)与订阅者异步接收(sub)示例代码可能的副作用: 2. 适度增加缓存和队列示例代码副作用: 3. 动态的IPC通道管理示例代码副作用: 4. 接收消息的超时设置示例代码副作用: 5. 增加I/O线程数量示例代码副作用: 6. 异步消息发送(使用`dontwait`标志)示例代码副作用: 7. 其他可以考虑的优化项7.1 立即发送(ZMQ_IM