Python 常用模块threading和Thread模块之线程池

2023-12-16Python编程
26

线程池是线程的一个集合,它可以在限定数量的线程中,重复利用这些线程来处理多个任务,从而实现线程池的功能。

Python中的threading库提供了ThreadPoolExecutor类,它提供了很多线程池操作方法,让开发者可以在多线程编程中更加便捷地使用线程池。

ThreadPoolExecutor

ThreadPoolExecutor类是一个线程池管理器,它可以维护线程池中的线程,并配合submit()方法接受任务,提供线程池的基本管理功能。

ThreadPoolExecutor类有以下几个重要的参数:

  • max_workers:线程池中的最大线程数。
  • thread_name_prefix:线程名的前缀,可以使用该参数给线程一个可辨识的标识。
  • thread_pool_executor:线程池管理器。

示例1:创建线程池并提交任务

下面的示例演示了如何创建一个线程池,提交一个无参的任务,并在任务执行完成后关闭线程池:

from concurrent.futures import ThreadPoolExecutor
import time

# 定义一个任务
def task():
    print("开始执行任务...")
    time.sleep(2)
    print("任务执行完成!")

# 创建一个线程池
pool = ThreadPoolExecutor(max_workers=5, thread_name_prefix="my_thread_")

# 提交一个任务
future = pool.submit(task)

# 等待任务完成
future.result()

# 关闭线程池
pool.shutdown(wait=True)

上面的代码生成了一个名为“my_thread_”的线程池,最多同时执行5个线程,接着我们将一个简单的无参任务task()提交给线程池,然后等待任务完成后关闭线程池。

示例2:同时提交多个任务

下面的示例演示了如何提交三个任务,并在所有任务完成后关闭线程池:

from concurrent.futures import ThreadPoolExecutor
import time

def task(index):
    print(f"任务{index}开始执行...")
    time.sleep(2)
    print(f"任务{index}执行完成!")

# 创建一个线程池
pool = ThreadPoolExecutor(max_workers=5, thread_name_prefix="my_thread_")

# 提交三个任务
for i in range(3):
    pool.submit(task, i)

# 关闭线程池
pool.shutdown(wait=True)

上面的代码中定义了一个任务task(index),我们使用循环三次,分别提交了三个任务到线程池中,然后等待所有任务完成后关闭线程池。

Thread

Python中的Thread类也提供了实现多线程的方式,并且Thread类有比ThreadPoolExecutor更强大的功能,可以更加自由控制线程的创建和执行过程。Thread类的使用方法如下:

import threading

# 定义一个任务类
class MyTask(threading.Thread):
    def run(self):
        print("开始执行任务...")
        time.sleep(2)
        print("任务执行完成!")

# 创建线程,开始任务
t = MyTask()
t.start()

上面的代码中,我们定义了一个类MyTask,它继承了threading.Thread类,并重写了run()方法。在run()方法中定义了一个简单的任务。

创建线程的对象t是MyTask的实例,我们调用它的start()方法,就启动了这个线程,开始执行任务。

总而言之,线程池作为多线程编程中的一种重要方式,可以避免线程的过多开销和资源浪费,提高程序的运行效率。Python的线程库threading提供的ThreadPoolExecutor类可以方便地实现线程池的操作,同时Thread类也可以实现自定义线程的逻辑,开发者可以根据实际需求选择合适的方式来进行多线程编程。

The End

相关推荐

解析Python中的eval()、exec()及其相关函数
Python中有三个内置函数eval()、exec()和compile()来执行动态代码。这些函数能够从字符串参数中读取Python代码并在运行时执行该代码。但是,使用这些函数时必须小心,因为它们的不当使用可能会导致安全漏洞。...
2023-12-18 Python编程
117

Python下载网络文本数据到本地内存的四种实现方法示例
在Python中,下载网络文本数据到本地内存是常见的操作之一。本文将介绍四种常见的下载网络文本数据到本地内存的实现方法,并提供示例说明。...
2023-12-18 Python编程
101

Python 二进制字节流数据的读取操作(bytes与bitstring)
来给你详细讲解下Python 二进制字节流数据的读取操作(bytes与bitstring)。...
2023-12-18 Python编程
120

Python3.0与2.X版本的区别实例分析
Python 3.x 是 Python 2.x 的下一个重大版本,其中有一些值得注意的区别。 Python 3.0中包含了许多不兼容的变化,这意味着在迁移到3.0之前,必须进行代码更改和测试。本文将介绍主要的差异,并给出一些实例来说明不同点。...
2023-12-18 Python编程
34

python如何在终端里面显示一张图片
要在终端里显示图片,需要使用一些Python库。其中一种流行的库是Pillow,它有一个子库PIL.Image可以加载和处理图像文件。要在终端中显示图像,可以使用如下的步骤:...
2023-12-18 Python编程
91

Python图像处理实现两幅图像合成一幅图像的方法【测试可用】
在Python中,我们可以使用Pillow库来进行图像处理。具体实现两幅图像合成一幅图像的方法如下:...
2023-12-18 Python编程
103