美文网首页
Python 多线程 thread join() 的作用

Python 多线程 thread join() 的作用

作者: 忘了呼吸的那只猫 | 来源:发表于2018-10-17 10:22 被阅读55次

在 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)完成,所以自己在后面执行完成。

相关文章

  • Python 多线程 thread join() 的作用

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

  • Java多线程-Thread.join()

    Java多线程-Thread.join() Thread.join()把制定的线程加入到当前线程,可以将两个交替执...

  • Python 并行编程

    多线程编程 Python 主要提供了包括thread、threading、Queue等多线程编程模块。thread...

  • join方法

    作用join()是线程类Thread的方法,官方给出的说明是:Waits for this thread to d...

  • Java 面试题

    java多线程实现主线程等待子线程执行完问题 1、使用Thread的join()方法,join()方法会阻塞主线程...

  • java线程之Thread.join()方法

    1. Thread.join 方法的作用 方法 join 的作用是 使所属的线程对象正常执行 run() 方法中的...

  • Python多线程编程(一)

    1. threading模块 Python 实现多线程编程可以通过thread模块(thread模块在Python...

  • java并发工具类

    等待多线程完成 主线程等待所有线程完成工作 实现 thread.join()方法 原理 join 用于让当前执行线...

  • Thread.join 的作用

    thread.join 的含义是当前线程需要等待 previousThread 线程终止之后才从previousT...

  • Python爬虫(四)--多线程

    Python-Socket网络编程 1. thread模块 python是支持多线程的, 主要是通过thread和...

网友评论

      本文标题:Python 多线程 thread join() 的作用

      本文链接:https://www.haomeiwen.com/subject/gdylzftx.html