python 多进程之multiprocessing,daemon守护线程
创建函数并将其作为多个进程
将进程定义为类
结果:
多进程:
Daemon和join的用法
当一个进程启动之后,会默认产生一个主线程,因为线程是程序执行流的最小单元,当设置多线程时,主线程会创建多个子线程,
在python中,默认情况下(其实就是setDaemon(False)),主线程执行完自己的任务以后,就退出了,此时子线程会继续执行自己的任务,直到自己的任务结束
例:不加daemon属性
知识点二:
当我们使用setDaemon(True)方法,也就是设置子线程为守护线程时,主线程一旦执行结束,则全部线程全部被终止执行,可能出现的情况就是,子线程的任务还没有完全执行结束,就被迫停止。
例:加daemon属性
知识点三:
此时join的作用就凸显出来了,join所完成的工作就是线程同步,即主线程任务结束之后,进入阻塞状态,一直等待其他的子线程执行结束之后,主线程再终止,例子见下面。
加daemon属性和join方法
总结:
不设置daemon 主程序只管自己结束 ,然后子程序还在运行 设置了daemon 主程序结束了 就全结束了 所以要设置daemon+join 阻塞主程序,等待子程序运行结束后在运行主程序