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使用Beautiful Soup包编写爬虫时的一些关键点
Jan 20 Python
Python使用Pycrypto库进行RSA加密的方法详解
Jun 06 Python
详解python中的文件与目录操作
Jul 11 Python
Django自定义过滤器定义与用法示例
Mar 22 Python
Python实现的简单线性回归算法实例分析
Dec 26 Python
python集合的创建、添加及删除操作示例
Oct 08 Python
python实现根据文件格式分类
Oct 31 Python
pytorch 修改预训练model实例
Jan 18 Python
python使用信号量动态更新配置文件的操作
Apr 01 Python
Django ORM实现按天获取数据去重求和例子
May 18 Python
python 星号(*)的多种用途
Sep 21 Python
Python如何执行系统命令
Sep 23 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
一些操作和快捷键的理解和讨论
2020/03/04 星际争霸
ThinkPHP实现多数据库连接的解决方法
2014/07/01 PHP
PHP中$GLOBALS与global的区别详解
2019/03/21 PHP
javascript之ESC(第二类混淆)
2007/05/06 Javascript
dropdownlist之间的互相联动实现(显示与隐藏)
2009/11/24 Javascript
Jquery时间验证和转换工具小例子
2013/07/01 Javascript
JavaScript使用Replace进行字符串替换的方法
2015/04/14 Javascript
javascript实现的图片切割多块效果实例
2015/05/07 Javascript
JavaScript 不支持 indexof 该如何解决
2016/03/30 Javascript
JavaScript必知必会(六) delete in instanceof
2016/06/08 Javascript
AngularJS Phonecat实例讲解
2016/11/21 Javascript
javascript实现右下角广告框效果
2017/02/01 Javascript
基于JavaScript实现淘宝商品广告效果
2017/08/10 Javascript
JavaScript异步加载问题总结
2018/02/17 Javascript
小程序实现列表删除功能
2018/10/30 Javascript
vue实现鼠标移入移出事件代码实例
2019/03/27 Javascript
tweenjs缓动算法的使用实例分析
2019/08/26 Javascript
vue 百度地图(vue-baidu-map)绘制方向箭头折线实例代码详解
2020/04/28 Javascript
Js生成随机数/随机字符串的方法小结【5种方法】
2020/05/27 Javascript
javascript读取本地文件和目录方法详解
2020/08/06 Javascript
在Python中操作文件之read()方法的使用教程
2015/05/24 Python
Python 列表理解及使用方法
2017/10/27 Python
基于Python执行dos命令并获取输出的结果
2019/12/30 Python
解决Tensorflow 内存泄露问题
2020/02/05 Python
pytorch masked_fill报错的解决
2020/02/18 Python
英国在线珠宝店:The Jewel Hut
2017/03/20 全球购物
Arti-shopping中文官网:大型海外商品一站式直邮平台
2020/03/23 全球购物
威盛公司软件C++工程师笔试题面试题
2012/07/16 面试题
触摸春天教学反思
2014/02/03 职场文书
汉语言文学职业规划
2014/02/14 职场文书
保护环境建议书
2014/03/12 职场文书
争先创优公开承诺书
2014/08/30 职场文书
单位员工收入证明样本
2014/10/09 职场文书
2014年文员工作总结
2014/11/18 职场文书
2016国庆节67周年寄语
2015/12/07 职场文书
学习nginx基础知识
2021/09/04 Servers