守护进程
主进程创建子进程,然后将该进程设置成守护自己的进程,守护进程就好比崇祯皇帝身边的老太监,崇祯皇帝已死老太监就跟着殉葬了。
关于守护进程需要强调两点:
守护进程会在主进程代码执行结束后就终止
守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic processes are not allowed to have children
如果我们有两个任务需要并发执行,那么开一个主进程和一个子进程分别去执行就ok了,如果子进程的任务在主进程任务结束后就没有存在的必要了,那么该子进程应该在开启前就被设置成守护进程。主进程代码运行结束,守护进程随即终止
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| 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也就跟着结束掉了
|
守护进程要在start前设置daemon=True 否则报错
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
| #守护进程一定是等到主进程结束然后终止运行 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-------")
''' 永远看不到 end123 因为执行到 main------之后 主进程就结束了 '''
|