多进程实现,daemon守护线程

python 新线程 python线程daemon_主线程

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

python 新线程 python线程daemon_子线程_02

 

 将进程定义为类

 

python 新线程 python线程daemon_多进程_03

 

结果: 

python 新线程 python线程daemon_主线程_04

 

 

多进程:

Daemon和join的用法

 

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

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

例:不加daemon属性

python 新线程 python线程daemon_主线程_05

 

 

python 新线程 python线程daemon_多进程_06

 

 

知识点二:

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

例:加daemon属性

python 新线程 python线程daemon_主线程_07

 

 

 

python 新线程 python线程daemon_主线程_08

 

 

 

知识点三:

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

加daemon属性和join方法

python 新线程 python线程daemon_主线程_09

 

 

总结:

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

 

python 新线程 python线程daemon_python 新线程_10