Python 多线程 thread join() 的作用

Python 多线程 thread join() 的作用原文地址在Python的多线程编程中,在实例代码中经常有thread1.join()这样的代码。那么今天咱们用实际代码来解释一下join函数的作用。join的原理就是依次检验线程池中的线程是否结束,没有结束就阻塞直到线程结束,如果结束则跳转执行下一个线程的join函数。先看看这个:1.阻塞主进程,专注于执行多线程中的程序。2.多线程多join的情况下,依次执行各线程的join方法…_pythonthread.join()作用

大家好,欢迎来到IT知识分享网。Python

原文地址

Python 的多线程编程中,在实例代码中经常有 thread1.join()这样的代码。那么今天咱们用实际代码来解释一下 join 函数的作用。

 

join的原理就是依次检验线程池中的线程是否结束,没有结束就阻塞直到线程结束,如果结束则跳转执行下一个线程的join函数。

 

先看看这个:

1. 阻塞主进程,专注于执行多线程中的程序。

2. 多线程多join的情况下,依次执行各线程的join方法,前头一个结束了才能执行后面一个。

3. 无参数,则等待到该线程结束,才开始执行下一个线程的join。

4. 参数timeout为线程的阻塞时间,如 timeout=2 就是罩着这个线程2s 以后,就不管他了,继续执行下面的代码。

 

代码示例:

# coding: utf-8
# 测试多线程中join的功能
import threading, time  
def doWaiting():  
    print 'start waiting1: ' + time.strftime('%H:%M:%S') + "\n"  
    time.sleep(3)  
    print 'stop waiting1: ' + time.strftime('%H:%M:%S') + "\n" 
def doWaiting1():  
    print 'start waiting2: ' + time.strftime('%H:%M:%S') + "\n"   
    time.sleep(8)  
    print 'stop waiting2: ', time.strftime('%H:%M:%S') + "\n"  
tsk = []    
thread1 = threading.Thread(target = doWaiting)  
thread1.start()  
tsk.append(thread1)
thread2 = threading.Thread(target = doWaiting1)  
thread2.start()  
tsk.append(thread2)
print 'start join: ' + time.strftime('%H:%M:%S') + "\n"   
for tt in tsk:
    tt.join()
print 'end join: ' + time.strftime('%H:%M:%S') + "\n"

 

CASE1:

按照代码示例中的代码执行。

 

执行结果:

start waiting1: 00:39:03

start waiting2: 00:39:03

start join: 00:39:03

stop waiting1: 00:39:06

stop waiting2:  00:39:11

end join: 00:39:11

[Finished in 8.0s]

 

执行结果分析:

1. 两个线程在同一时间开启,join 函数执行。

2. waiting1 线程执行(等待)了3s 以后,结束。

3. waiting2 线程执行(等待)了8s 以后,运行结束。

4. join 函数(返回到了主进程)执行结束。

 

CASE2:

将 join 的参数改成2 即 tt.join(2)

 

执行结果:

start waiting1: 00:45:32
start waiting2: 00:45:32

start join: 00:45:32

stop waiting1: 00:45:35

end join: 00:45:36

stop waiting2:  00:45:40

[Finished in 8.0s]

 

执行结果分析:

1. 两个线程在同一时间开启,join 函数执行。

2. wating1 线程在执行(等待)了三秒以后,完成。

3. join 退出(两个2s,一共4s,36-32=4,无误)。

4. waiting2 线程由于没有在 join 规定的等待时间内(4s)完成,所以自己在后面执行完成。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/27349.html

(0)
上一篇 2023-12-10 18:15
下一篇 2023-12-12 13:15

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信