python线程join方法原理解析


Posted in Python onFebruary 11, 2020

这篇文章主要介绍了python线程join方法原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

几个事实

1 python 默认参数创建线程后,不管主线程是否执行完毕,都会等待子线程执行完毕才一起退出,有无join结果一样

2 如果创建线程,并且设置了daemon为true,即thread.setDaemon(True), 则主线程执行完毕后自动退出,不会等待子线程的执行结果。而且随着主线程退出,子线程也消亡。

3 join方法的作用是阻塞,等待子线程结束,join方法有一个参数是timeout,即如果主线程等待timeout,子线程还没有结束,则主线程强制结束子线程。

4 如果线程daemon属性为False, 则join里的timeout参数无效。主线程会一直等待子线程结束。

5 如果线程daemon属性为True, 则join里的timeout参数是有效的, 主线程会等待timeout时间后,结束子线程。此处有一个坑,即如果同时有N个子线程join(timeout),那么实际上主线程会等待的超时时间最长为 N * timeout, 因为每个子线程的超时开始时刻是上一个子线程超时结束的时刻。

测试代码

import threading,time

def func():
  print "start thread time: ",time.strftime('%H:%M:%S')
  time.sleep(3)
  print "stop thread time: ",time.strftime('%H:%M:%S')

thread_list = []
for i in range(3):
  t1 = threading.Thread(target=func)
  #t1.setDaemon(True)

  thread_list.append(t1)

for r in thread_list:
  r.start()

for t in thread_list:
  #t.join(1)
  t.join()
print "stop main thread"

###子线程如果设置了t.join(timeout),则根据timeout的不同,结果会不同,前提是设置了setDaemon(True),否则join的timeout是没效的

#设置了setDaemon(True),但是没设置t.join()的运行结果:
#start thread time: 17:25:29
#start thread time: 17:25:29
#start thread time: 17:25:29
#stop main thread

#加了t1.setDaemon(True),并且设置了超时时间t.join(1)的运行结果:
#start thread time: 17:12:24
#start thread time: 17:12:24
#start thread time: 17:12:24
#stop main thread

#没加t1.setDaemon(True),并且设置了超时时间t.join(1)的运行结果,不过因为setDaemon的参数不是True所以就算设置了超时时间也没用:
#start thread time: 17:13:28
#start thread time: 17:13:28
#start thread time: 17:13:28
#stop main thread
#stop thread time:  17:13:31
#stop thread time:  17:13:31
#stop thread time:  17:13:31

#没加t1.setDaemon(True),但是设置了t.join(),没有超时时间的阻塞的运行结果:
#start thread time: 17:16:12
#start thread time: 17:16:12
#start thread time: 17:16:12
#stop thread time:  17:16:15
#stop thread time:  17:16:15
#stop thread time:  17:16:15
#stop main thread 

#即没有设置setDaemon(True),也没有设置join()的运行结果:
#start thread time: 17:22:25
#start thread time: 17:22:25
#start thread time: 17:22:25
#stop main thread
#stop thread time:  17:22:28
#stop thread time:  17:22:28
#stop thread time:  17:22:28

总结:

如果想让子进程正常的运行结束(子进程中所有的内容都运行了),则如果设置join(timeout)的话,前提是设置setDaemon(True),且setDaemon的参数为True,且join(timeout)的超时时间必须大于子进程执行所需的时间,不然没等子进程运行结束就超时退出了或者直接设置join()不带超时时间,也不用设置setDaemon(True)了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Windows下安装python2.7及科学计算套装
Mar 05 Python
Python扩展内置类型详解
Mar 26 Python
关于Tensorflow中的tf.train.batch函数的使用
Apr 24 Python
利用python如何处理百万条数据(适用java新手)
Jun 06 Python
Tensorflow 训练自己的数据集将数据直接导入到内存
Jun 19 Python
celery4+django2定时任务的实现代码
Dec 23 Python
15行Python代码实现网易云热门歌单实例教程
Mar 10 Python
Python监控服务器实用工具psutil使用解析
Dec 19 Python
基于keras 模型、结构、权重保存的实现
Jan 24 Python
Tensorflow训练模型越来越慢的2种解决方案
Feb 07 Python
django models里数据表插入数据id自增操作
Jul 15 Python
Python用摘要算法生成token及检验token的示例代码
Dec 01 Python
使用Python求解带约束的最优化问题详解
Feb 11 #Python
python 非线性规划方式(scipy.optimize.minimize)
Feb 11 #Python
使用遗传算法求二元函数的最小值
Feb 11 #Python
Python for循环搭配else常见问题解决
Feb 11 #Python
Python获取二维数组的行列数的2种方法
Feb 11 #Python
使用Puppeteer爬取微信文章的实现
Feb 11 #Python
Python实现遗传算法(二进制编码)求函数最优值方式
Feb 11 #Python
You might like
php 静态页面中显示动态内容
2009/08/14 PHP
php实现转换ubb代码的方法
2015/06/18 PHP
php将文件夹打包成zip文件的简单实现方法
2016/10/04 PHP
客户端脚本中常常出现的一些问题和调试技巧
2007/01/09 Javascript
javascript引用对象的方法代码
2007/08/13 Javascript
Jquery 的扩展方法总结
2011/10/01 Javascript
javascript date格式化示例
2013/09/25 Javascript
JavaScript判断变量是否为undefined的两种写法区别
2013/12/04 Javascript
基于jQuery的图片不完全按比例自动缩小
2014/07/11 Javascript
jquery实现拖拽调整Div大小
2015/01/30 Javascript
同步文本框内容JS代码实现
2016/08/04 Javascript
浅谈jQuery中事情的动态绑定
2017/02/12 Javascript
微信小程序 flex实现导航实例详解
2017/04/26 Javascript
详解微信小程序Radio选中样式切换
2017/07/06 Javascript
vue路由懒加载的实现方法
2018/03/12 Javascript
解决angular双向绑定无效果,ng-model不能正常显示的问题
2018/10/02 Javascript
JS闭包原理与应用经典示例
2018/12/20 Javascript
Vue中实现权限控制的方法示例
2019/06/07 Javascript
JS实现iframe中子父页面跨域通讯的方法分析
2020/03/10 Javascript
react结合bootstrap实现评论功能
2020/05/30 Javascript
如何搭建一个完整的Vue3.0+ts的项目步骤
2020/10/18 Javascript
Python程序设计入门(4)模块和包
2014/06/16 Python
使用opencv将视频帧转成图片输出
2019/12/10 Python
django项目中使用云片网发送短信验证码的实现
2021/01/19 Python
葡萄牙航空官方网站:TAP Air Portugal
2019/10/31 全球购物
ParcelABC西班牙:包裹运送和快递服务
2019/12/24 全球购物
什么是反射?如何实现反射?
2016/07/25 面试题
采购主管工作职责
2013/12/12 职场文书
基本公共卫生服务健康教育工作方案
2014/05/22 职场文书
社区文艺活动方案
2014/08/19 职场文书
一份恶作剧的检讨书
2014/09/13 职场文书
乡镇群众路线整改落实情况汇报
2014/10/28 职场文书
巾帼标兵事迹材料
2014/12/26 职场文书
经典祝酒词大全
2015/08/12 职场文书
HTML5来实现本地文件读取和写入的实现方法
2021/05/25 HTML / CSS
Python中的np.argmin()和np.argmax()函数用法
2021/06/02 Python