Python THREADING模块中的JOIN()方法深入理解


Posted in Python onFebruary 18, 2015

看了oschina上的两个代码,受益匪浅。其中对join()方法不理解,看python官网文档的介绍:
join([timeout]):等待直到进程结束。这将阻塞正在调用的线程,直到被调用join()方法的线程结束。(好难翻译,应该是这个意思)

哈哈,这个易懂。
join方法,如果一个线程或者一个函数在执行过程中要调用另外一个线程,并且待到其完成以后才能接着执行,那么在调用这个线程时可以使用被调用线程的join方法。

#-*- encoding: gb2312 -*-

import string, threading, time

 

def thread_main(a):

    global count, mutex

    # 获得线程名

    threadname = threading.currentThread().getName()

 

    for x in xrange(0, int(a)):

        # 取得锁

        mutex.acquire()

        count = count + 1

        # 释放锁

        mutex.release()

        print threadname, x, count

        time.sleep(1)

 

def main(num):

    global count, mutex

    threads = []

 

    count = 1

    # 创建一个锁

    mutex = threading.Lock()

    # 先创建线程对象

    for x in xrange(0, num):

        threads.append(threading.Thread(target=thread_main, args=(10,)))

    # 启动所有线程

    for t in threads:

        t.start()

    # 主线程中等待所有子线程退出

    for t in threads:

        t.join()  

 

if __name__ == '__main__':

    num = 4

    # 创建4个线程

    main(4)

###################################################################

#-*- encoding: gb2312 -*-

import threading

import time

 

class Test(threading.Thread):

    def __init__(self, num):

        threading.Thread.__init__(self)

        self._run_num = num

 

    def run(self):

        global count, mutex

        threadname = threading.currentThread().getName()

 

        for x in xrange(0, int(self._run_num)):

            mutex.acquire()

            count = count + 1

            mutex.release()

            print threadname, x, count

            time.sleep(1)

 

if __name__ == '__main__':

    global count, mutex

    threads = []

    num = 4

    count = 1

    # 创建锁

    mutex = threading.Lock()

    # 创建线程对象

    for x in xrange(0, num):

        threads.append(Test(10))

    # 启动线程

    for t in threads:

        t.start()

    # 等待子线程结束

    for t in threads:

        t.join()

在程序中,最后join()方法的调用就明白了,是主进程挨个调用子线程的join()方法。当四个线程都执行完毕后,主线程才会执行下面的代码,在这里也就是退出了。
相对应的在网上一起找到的另一个方法:
3.守护进程

setDaemon()

这个方法基本和join是相反的。当我们在程序运行中,执行一个主线程,如果主线程又创建一个子线程,主线程和子线程就分兵两路,分别运行,那么当主线程完成想退出时,会检验子线程是否完成。如果子线程未完成,则主线程会等待子线程完成后再退出。但是有时候我们需要的是,只要主线程完成了,不管子线程是否完成,都要和主线程一起退出,这时就可以用setDaemon方法啦

Python 相关文章推荐
python pdb调试方法分享
Jan 21 Python
python实现将pvr格式转换成pvr.ccz的方法
Apr 28 Python
Numpy中转置transpose、T和swapaxes的实例讲解
Apr 17 Python
python excel使用xlutils类库实现追加写功能的方法
May 02 Python
python3 爬取图片的实例代码
Nov 06 Python
python+PyQT实现系统桌面时钟
Jun 16 Python
安装好Pycharm后如何配置Python解释器简易教程
Jun 28 Python
使用OpenCV实现仿射变换—旋转功能
Aug 29 Python
Python实现快速排序的方法详解
Oct 25 Python
python 字段拆分详解
Dec 17 Python
基于python生成英文版词云图代码实例
May 16 Python
Python如何给函数库增加日志功能
Aug 04 Python
python持久性管理pickle模块详细介绍
Feb 18 #Python
Python中暂存上传图片的方法
Feb 18 #Python
Python中AND、OR的一个使用小技巧
Feb 18 #Python
Python编写屏幕截图程序方法
Feb 18 #Python
Python处理RSS、ATOM模块FEEDPARSER介绍
Feb 18 #Python
Python内置函数Type()函数一个有趣的用法
Feb 18 #Python
Python中使用MELIAE分析程序内存占用实例
Feb 18 #Python
You might like
php入门教程 精简版
2009/12/13 PHP
PHP JSON 数据解析代码
2010/05/26 PHP
一个PHP验证码类代码分享(已封装成类)
2011/07/17 PHP
浅谈php优化需要注意的地方
2014/11/27 PHP
php简单实现文件或图片强制下载的方法
2016/12/06 PHP
php 开发中加密的几种方法总结
2017/03/22 PHP
JQuery的Alert消息框插件使用介绍
2010/10/09 Javascript
Extjs4中tree的拖拽功能(可以两棵树之间拖拽) 简单实例
2013/12/08 Javascript
NodeJS学习笔记之Connect中间件模块(二)
2015/01/27 NodeJs
js实现的tab标签切换效果代码分享
2015/08/25 Javascript
Javascript实现检测客户端类型代码封包
2015/12/03 Javascript
js检查是否关闭浏览器的方法
2016/08/02 Javascript
JavaScript生成验证码并实现验证功能
2016/09/24 Javascript
使用Angular缓存父页面数据的方法
2017/01/03 Javascript
js实现产品缩略图效果
2017/03/10 Javascript
JS排序之选择排序详解
2017/04/08 Javascript
使用Nodejs连接mongodb数据库的实现代码
2017/08/21 NodeJs
JavaScript惰性求值的一种实现方法示例
2019/01/11 Javascript
Vue的click事件防抖和节流处理详解
2019/11/13 Javascript
JavaScrip如果基于url实现图片下载
2020/07/03 Javascript
Python抓取Discuz!用户名脚本代码
2013/12/30 Python
python链接Oracle数据库的方法
2015/06/28 Python
Python3 io文本及原始流I/O工具用法详解
2020/03/23 Python
在keras下实现多个模型的融合方式
2020/05/23 Python
Python中使用aiohttp模拟服务器出现错误问题及解决方法
2020/10/31 Python
德国古洛迷亚百货官网:GALERIA Kaufhof
2017/06/20 全球购物
莫斯科制造商的廉价皮大衣:Fursk
2020/06/09 全球购物
什么是三层交换,说说和路由的区别在那里
2014/09/01 面试题
我的网上商城创业计划书
2013/12/26 职场文书
事业单位公务员的职业生涯规划
2014/01/15 职场文书
高中历史教学反思
2014/02/08 职场文书
小学作文评语大全
2014/04/21 职场文书
大学生实习鉴定评语
2014/04/25 职场文书
通信工程求职信
2014/07/16 职场文书
效能风暴心得体会
2014/09/04 职场文书
2015年毕业实习工作总结
2014/12/12 职场文书