北京seo网站,新品发布会策划流程,网页工具在哪里,wordpress 页面怎么添加表格【一】僵尸进程
1.僵尸进程是指完成自己的任务之后#xff0c;没有被父进程回收资源,占用系统资源,对计算机有害#xff0c;应该避免所有的子进程在运行结束之后都会变成僵尸进程(死了没死透)还保留着pid和一些运行过程的中的记录便于主进程查看(短时间…【一】僵尸进程
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__:p1Process(targettask1,)p2Process(targettask2,)p1.daemonTruep1.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(targetfoo)p2 Process(targetbar)
p1.daemon Truep1.start()p2.start()
# 打印该行则主进程代码结束,则守护进程p1应该被终止,可能会有p1任务执行的打印信息123# 因为主进程打印main----时,p1也执行了,但是随即被终止print(main-------)# main-------# 456# end456