首页 > Python基础教程 > Python并发编程
阅读:3,857
Python Thread join()用法详解
Thread 提供了让一个线程等待另一个线程完成的 join() 方法。当在某个程序执行流中调用其他线程的 join() 方法时,调用线程将被阻塞,直到被 join() 方法加入的 join 线程执行完成。
join() 方法通常由使用线程的程序调用,以将大问题划分成许多小问题,并为每个小问题分配一个线程。当所有的小问题都得到处理后,再调用主线程来进一步操作。
在名为“被Join的线程”的线程执行时,实际上只有两个子线程并发执行,而主线程处于等待状态。运行上面程序,将会看到如图 1 所示的运行效果。
图 1 主线程等待 join 线程的效果
从图 1 中可以看出,主线程执行到 i==20 时,程序启动并 join了名为“被Join的线程”的线程,所以主线程将一直处于阻塞状态,直到名为“被Join的线程”的钱程执行完成。
join() 方法通常由使用线程的程序调用,以将大问题划分成许多小问题,并为每个小问题分配一个线程。当所有的小问题都得到处理后,再调用主线程来进一步操作。
import threading # 定义action函数准备作为线程执行体使用 def action(max): for i in range(max): print(threading.current_thread().name + " " + str(i)) # 启动子线程 threading.Thread(target=action, args=(100,), name="新线程").start() for i in range(100): if i == 20: jt = threading.Thread(target=action, args=(100,), name="被Join的线程") jt.start() # 主线程调用了jt线程的join()方法,主线程 # 必须等jt执行结束才会向下执行 jt.join() print(threading.current_thread().name + " " + str(i))上面程序中一共有三个线程,主程序开始时就启动了名为“新线程”的子线程,该子线程将会和主线程并发执行。当主线程的循环变量 i 等于 20 时,启动了名为“被Join的线程”的线程,该线程不会和主线程并发执行,主线程必须等该线程执行结束后才可以向下执行。
在名为“被Join的线程”的线程执行时,实际上只有两个子线程并发执行,而主线程处于等待状态。运行上面程序,将会看到如图 1 所示的运行效果。
图 1 主线程等待 join 线程的效果
从图 1 中可以看出,主线程执行到 i==20 时,程序启动并 join了名为“被Join的线程”的线程,所以主线程将一直处于阻塞状态,直到名为“被Join的线程”的钱程执行完成。
join(timeout=None)
方法可以指定一个 timeout 参数,该参数指定等待被 join 的线程的时间最长为 timeout 秒。如果在 timeout 秒内被 join 的线程还没有执行结束,则不再等待。所有教程
- socket
- Python基础教程
- C#教程
- MySQL函数
- MySQL
- C语言入门
- C语言专题
- C语言编译器
- C语言编程实例
- GCC编译器
- 数据结构
- C语言项目案例
- C++教程
- OpenCV
- Qt教程
- Unity 3D教程
- UE4
- STL
- Redis
- Android教程
- JavaScript
- PHP
- Mybatis
- Spring Cloud
- Maven
- vi命令
- Spring Boot
- Spring MVC
- Hibernate
- Linux
- Linux命令
- Shell脚本
- Java教程
- 设计模式
- Spring
- Servlet
- Struts2
- Java Swing
- JSP教程
- CSS教程
- TensorFlow
- 区块链
- Go语言教程
- Docker
- 编程笔记
- 资源下载
- 关于我们
- 汇编语言
- 大数据
- 云计算
- VIP视频