ThreadPoolExecutor().shutdown()
`ThreadPoolExecutor` 是 Python 标准库 `concurrent.futures` 模块中的一个类,用于创建一个线程池来管理多个线程的执行。线程池可以有效地管理线程的生命周期,避免频繁创建和销毁线程的开销,并可以控制同时运行的线程数量。
`shutdown()` 方法是 `ThreadPoolExecutor` 的一个实例方法,用于关闭线程池。当调用这个方法时,线程池会停止接受新的任务,并且等待所有正在执行的任务完成。一旦所有任务完成,线程池中的所有线程都会被销毁。
下面是 `shutdown()` 方法的一些关键点:
1. **停止接受新任务**:一旦调用 `shutdown()`,线程池就不会再接受任何新的任务。如果尝试提交新任务,将会抛出 `RuntimeError` 异常。
2. **等待任务完成**:线程池会等待所有已经提交的任务完成。这意味着,如果线程池中有正在执行的任务,`shutdown()` 调用会阻塞,直到这些任务执行完毕。
3. **销毁线程**:所有任务完成后,线程池中的线程会被销毁。
下面是一个使用 `ThreadPoolExecutor` 和 `shutdown()` 方法的示例:
import concurrent.futures
import time
# 定义一个简单的任务函数
def task(n):
print(f"Task {n} is running")
time.sleep(1) # 模拟任务执行时间
print(f"Task {n} is done")
# 创建一个线程池,最大线程数为5
with concurrent.futures.ThreadPoolExecutor(max_workers=5) as executor:
# 提交多个任务到线程池
futures = [executor.submit(task, n) for n in range(10)]
# 等待所有任务完成
concurrent.futures.wait(futures)
# 调用 shutdown() 方法关闭线程池
executor.shutdown()
在这个例子中,我们创建了一个最大线程数为 5 的线程池,并提交了 10 个任务。每个任务简单地打印开始和结束的信息,并休眠 1 秒。我们使用 `wait()` 函数等待所有任务完成,然后调用 `shutdown()` 方法关闭线程池。注意,示例使用了 `with` 语句来自动管理线程池的创建和关闭。