多进程-守护进程
一、守护进程
p.daemon = True # 一定要在p.start()前设置,设置p为守护进程,禁止p创建子进程,并且父进程代码执行结束,p即终止运行
主进程创建子进程,然后将该进程设置成守护自己的进程,守护进程就好比崇祯皇帝身边的老太监,崇祯皇帝已死老太监就跟着殉葬了。
关于守护进程需要强调两点:
其一:守护进程会在主进程代码执行结束后就终止
其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic processes are not allowed to have children
如果我们有两个任务需要并发执行,那么开一个主进程和一个子进程分别去执行就ok了,如果子进程的任务在主进程任务结束后就没有存在的必要了,那么该子进程应该在开启前就被设置成守护进程。主进程代码运行结束,守护进程随即终止
from multiprocessing import Process
import time
import random
def task(name):
print('%s is piaoing' % name)
time.sleep(random.randrange(1, 3))
print('%s is piao end' % name)
if __name__ == '__main__':
p = Process(target=task, args=('egon',))
p.daemon = True # 一定要在p.start()前设置,设置p为守护进程,禁止p创建子进程,并且父进程代码执行结束,p即终止运行
p.start()
print('主') # 只要终端打印出这一行内容,那么守护进程p也就跟着结束掉了
二、练习题:
思考下列代码的执行结果有可能有哪些情况?为什么?
from multiprocessing import Process
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=True
p1.start()
p2.start()
print("main-------")
结果输出:
main------- 456 end456
因为p1设为了守护进程,然后p1和p2同时向操作系统发出运行信号,随即就运行了主进程代码,打印出 main------ ,这时主进程代码运行完成,那么守护进程就应该和主进程一起殉葬了,所以p1就不会运行了,但是p2不是守护进程,依然会继续运行,所以接着就打印 456, end456
共有 0 条评论