python并发编程多进程之守护进程原理解析
2019-08-20 14:31
2311 查看
守护进程
主进程创建子进程目的是:主进程有一个任务需要并发执行,那开启子进程帮我并发执行任务
主进程创建子进程,然后将该进程设置成守护自己的进程
关于守护进程需要强调两点:
其一:守护进程会在主进程代码执行结束后就终止
其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic processes are not allowed to have children
如果我们有两个任务需要并发执行,那么开一个主进程和一个子进程分别去执行就ok了,如果子进程的任务在主进程任务结束后,就没有存在的必要了,那么该子进程应该在开启前就被设置成守护进程。主进程代码运行结束,守护进程随即终止
子进程还没来得及开始就挂了
设置了守护进程 就是不给子进程运行
守护进程必须在开启子进程前开启
from multiprocessing import Process import time def task(name): print("%s is running" % name) time.sleep(3) print("%s is done" % name) if __name__ == "__main__": t = Process(target=task, args=('子进程1',)) # 守护进程必须在开启子进程前开启 t.daemon = True t.start() print("主") ''' 主 '''
开一个子进程是为了并发任务, 这个子进程的任务,在主进程死了,这个任务就没有意义存在,这个子进程就应该设置守护进程
守护进程练习题
在主进程代码执行完毕,只要出现打印主进程信息,p1就不会执行或者死掉
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------- end456 '''
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- python并发编程多进程 互斥锁原理解析
- python并发编程之守护进程、互斥锁以及生产者和消费者模型
- 理解python并发编程-进程篇
- linux下python守护进程编写和原理理解
- python守护进程编写和原理理解
- [Python网络编程]浅析守护进程后台任务的设计与实现
- Python并发编程-进程
- Python并发编程之进程
- Python并发编程之进程
- 4 并发编程-(进程)-守护进程&互斥锁
- Python3 与 C# 并发编程之~ 进程篇
- [Python网络编程]浅析守护进程后台任务的设计与实现
- Python并发编程之进程
- JAVA并发编程原理与实战ScheduledThreadPoolExecutor 实现原理与源码深度解析视频教程
- Java 并发编程:volatile的使用及其原理解析
- python3全栈开发-并发编程的多进程理论
- Python3 与 C# 并发编程之~ 进程篇
- Python并发编程-进程
- Python并发编程之进程
- Python并发编程之常用概念剖析:并行 串行 并发 同步 异步 阻塞 非阻塞 进程 线程 协程