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读取浮点数和读取文本文件示例
May 06 Python
python文件读写操作与linux shell变量命令交互执行的方法
Jan 14 Python
Python标准库inspect的具体使用方法
Dec 06 Python
win7下python3.6安装配置方法图文教程
Jul 31 Python
Python爬虫小技巧之伪造随机的User-Agent
Sep 13 Python
Python3 串口接收与发送16进制数据包的实例
Jun 12 Python
Python利用Scrapy框架爬取豆瓣电影示例
Jan 17 Python
详解Django3中直接添加Websockets方式
Feb 12 Python
python安装后的目录在哪里
Jun 21 Python
Django中和时区相关的安全问题详解
Oct 12 Python
Python3中FuzzyWuzzy库实例用法
Nov 18 Python
Python基础之操作MySQL数据库
May 06 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
建立动态的WML站点(二)
2006/10/09 PHP
php设计模式之命令模式的应用详解
2013/05/21 PHP
PHP大小写问题:函数名和类名不区分,变量名区分
2013/06/17 PHP
CI框架装载器Loader.php源码分析
2014/11/04 PHP
thinkPHP2.1自定义标签库的导入方法详解
2016/07/20 PHP
javascript 常用关键字列表集合
2007/12/04 Javascript
IE php关于强制下载文件的代码
2008/08/23 Javascript
Prototype Template对象 学习
2009/07/19 Javascript
XMLHttpRequest处理xml格式的返回数据(示例代码)
2013/11/21 Javascript
javascript面向对象特性代码实例
2014/06/12 Javascript
jquery制作LED 时钟特效
2015/02/01 Javascript
javascript实现网页字符定位的方法
2015/07/14 Javascript
基于BootStrap Metronic开发框架经验小结【一】框架总览及菜单模块的处理
2016/05/12 Javascript
AngularJS API之copy深拷贝详解及实例
2016/09/14 Javascript
vue router路由嵌套不显示问题的解决方法
2017/06/17 Javascript
详解React Native 屏幕适配(炒鸡简单的方法)
2018/06/11 Javascript
Vue表单输入绑定的示例代码
2018/11/01 Javascript
微信小程序tabBar设置实例解析
2019/11/14 Javascript
d3.js 地铁轨道交通项目实战
2019/11/27 Javascript
vue接通后端api以及部署到服务器操作
2020/08/13 Javascript
解决vant的Toast组件时提示not defined的问题
2020/11/11 Javascript
[02:43]DOTA2英雄基础教程 半人马战行者
2014/01/13 DOTA
彻底搞懂Python字符编码
2018/01/23 Python
python 基于opencv实现高斯平滑
2020/12/18 Python
html5 input输入实时检测以及延时优化
2018/07/18 HTML / CSS
德国电子商城:ComputerUniverse
2017/04/21 全球购物
大学生预备党员自我评价分享
2013/11/16 职场文书
《小小竹排画中游》教学反思
2014/02/26 职场文书
自主招生自荐信格式范文
2015/03/25 职场文书
酒店财务经理岗位职责
2015/04/08 职场文书
2016大学生社会实践心得体会范文
2016/01/14 职场文书
《我是什么》教学反思
2016/02/16 职场文书
描述鲁迅的名言整理,一生受用
2019/08/08 职场文书
Filebeat 采集 Nginx 日志的方法
2021/03/31 Servers
Python实现生成bmp图像的方法
2021/06/13 Python
使用feign服务调用添加Header参数
2021/06/23 Java/Android