在 Python 的多线程编程中,在实例代码中常常有 thread1.join()这样的代码。那么今天我们用实际代码来解释一下 join 函数的做用。编程
join的原理就是依次检验线程池中的线程是否结束,没有结束就阻塞直到线程结束,若是结束则跳转执行下一个线程的join函数。多线程
先看看这个:app
1. 阻塞主进程,专一于执行多线程中的程序。函数
2. 多线程多join的状况下,依次执行各线程的join方法,前头一个结束了才能执行后面一个。测试
3. 无参数,则等待到该线程结束,才开始执行下一个线程的join。spa
4. 参数timeout为线程的阻塞时间,如 timeout=2 就是罩着这个线程2s 之后,就无论他了,继续执行下面的代码。.net
代码示例:线程
# 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:code
按照代码示例中的代码执行。htm
执行结果:
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)完成,因此本身在后面执行完成。
参考链接:
http://www.jb51.net/article/54628.htm