python 多进程之multiprocessing,daemon守护线程

 

 创建函数并将其作为多个进程

 

 将进程定义为类

 

 

结果: 

 

 

多进程:

Daemon和join的用法

 

当一个进程启动之后,会默认产生一个主线程,因为线程是程序执行流的最小单元,当设置多线程时,主线程会创建多个子线程,

python中,默认情况下(其实就是setDaemon(False)),主线程执行完自己的任务以后,就退出了,此时子线程会继续执行自己的任务,直到自己的任务结束

例:不加daemon属性

 

 

 

 

知识点二:

当我们使用setDaemon(True)方法,也就是设置子线程为守护线程时,主线程一旦执行结束,则全部线程全部被终止执行,可能出现的情况就是,子线程的任务还没有完全执行结束,就被迫停止。

例:daemon属性

 

 

 

 

 

 

知识点三:

此时join的作用就凸显出来了,join所完成的工作就是线程同步,即主线程任务结束之后,进入阻塞状态,一直等待其他的子线程执行结束之后,主线程再终止,例子见下面。

daemon属性和join方法

 

 

总结:

  不设置daemon 主程序只管自己结束 ,然后子程序还在运行  设置了daemon 主程序结束了 就全结束了  所以要设置daemon+join 阻塞主程序,等待子程序运行结束后在运行主程序

 

 

 

 

 

 

posted @ 2020-11-26 08:54  7dao  阅读(3218)  评论(0编辑  收藏  举报