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 相关文章推荐
举例讲解Django中数据模型访问外键值的方法
Jul 21 Python
Python中的super()方法使用简介
Aug 14 Python
Python中xml和json格式相互转换操作示例
Dec 05 Python
使用coverage统计python web项目代码覆盖率的方法详解
Aug 05 Python
python3 BeautifulSoup模块使用字典的方法抓取a标签内的数据示例
Nov 28 Python
Python OpenCV视频截取并保存实现代码
Nov 30 Python
django model 条件过滤 queryset.filter(**condtions)用法详解
May 20 Python
解决python图像处理图像赋值后变为白色的问题
Jun 04 Python
Python爬取网页信息的示例
Sep 24 Python
matplotlib绘制正余弦曲线图的实现
Feb 22 Python
Python GUI编程之tkinter 关于 ttkbootstrap 的使用详解
Mar 03 Python
Python语法学习之进程的创建与常用方法详解
Apr 08 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 Xdebug 调试扩展的安装与使用.
2010/03/13 PHP
一致性哈希算法以及其PHP实现详细解析
2013/08/24 PHP
php ZipArchive压缩函数详解实例
2013/11/06 PHP
ExtJs 3.1 XmlTreeLoader Example Error
2010/02/09 Javascript
javascript与有限状态机详解
2014/05/08 Javascript
通过JS来动态的修改url,实现对url的增删查改
2014/09/01 Javascript
JavaScript学习心得之概述
2015/01/20 Javascript
javascript获取文档坐标和视口坐标
2015/05/26 Javascript
Javascript中的数据类型之旅
2015/10/18 Javascript
JavaScript函数学习总结以及相关的编程习惯指南
2015/11/16 Javascript
基于BootStrap Metronic开发框架经验小结【九】实现Web页面内容的打印预览和保存操作
2016/05/12 Javascript
学做Bootstrap的第一个页面
2016/05/15 HTML / CSS
Vue结合原生js实现自定义组件自动生成示例
2017/01/21 Javascript
canvas绘制表盘时钟
2017/01/23 Javascript
Angular中的interceptors拦截器
2017/06/25 Javascript
微信小程序实现天气预报功能
2018/07/18 Javascript
js的各种数据类型判断的介绍
2019/01/19 Javascript
javascriptvoid(0)含义以及与"#"的区别讲解
2019/01/19 Javascript
ElementUI多个子组件表单的校验管理实现
2019/11/07 Javascript
[01:07:02]DOTA2-DPC中国联赛 正赛 iG vs PSG.LGD BO3 第三场 2月26日
2021/03/11 DOTA
python3实现SMTP发送邮件详细教程
2018/06/19 Python
详解Python3迁移接口变化采坑记
2019/10/11 Python
解决torch.autograd.backward中的参数问题
2020/01/07 Python
PyQt5通过信号实现MVC的示例
2021/02/06 Python
法国奢华女性时尚配饰网上商店:Monnier Frères
2016/08/27 全球购物
玩具反斗城天猫官方旗舰店:享誉全球的玩具店
2017/10/10 全球购物
船餐厅和泰晤士河餐饮游轮:Bateaux London
2018/03/19 全球购物
荷兰演唱会和体育比赛订票网站:viagogo荷兰
2018/04/08 全球购物
Camper鞋西班牙官方网上商店:西班牙马略卡岛的鞋类品牌
2019/03/14 全球购物
意大利网上药房:Farmacia 33
2020/01/27 全球购物
输入N,打印N*N矩阵
2012/02/20 面试题
《小石潭记》教学反思
2014/02/13 职场文书
城管大队整治方案
2014/05/06 职场文书
开学第一天的感想
2015/08/10 职场文书
Python 实现定积分与二重定积分的操作
2021/05/26 Python
利用 SQL Server 过滤索引提高查询语句的性能分析
2021/07/15 SQL Server