submit 方法来自 concurrent.futures 模块,用于向线程池提交函数并返回 Future 对象。1. 导入模块;2. 创建 ThreadPoolExecutor 实例;3. 调用 submit 提交任务;4. 通过 result() 获取结果。支持批量提交与 as_completed 按完成顺序获取结果,异常在 result() 中抛出,需用 try-except 处理。
Python 中的 submit 方法并不属于传统线程(如 threading.Thread)的一部分,而是来自 concurrent.futures 模块中的线程池执行器(ThreadPoolExecutor)。它用于提交一个函数到线程池中异步执行,并返回一个 Future 对象来获取结果。
使用 submit 的步骤如下:
示例代码:
from concurrent.futures import ThreadPoolExecutor import timedef task(n): time.sleep(1) return f"处理完成: {n}"
创建线程池
with ThreadPoolExecutor(max_workers=3) as executor:
提交任务
future = executor.submit(task, 5) # 获取结果(会阻塞直到完成) result = future.result() print(result)
executor.submit(func, *args, **kwargs)
例如:
future = executor.submit(task, 10, name="worker1")
如果需要提交多个任务,可以结合循环和 Future 对象列表:
futures = [executor.submit(task, i) for i in range(5)]for future in futures: print(future.result())
也可以使用 as_completed 来按完成顺序获取结果:
from concurrent.futures import as_completedfutures = [executor.submit(task, i) for i in range(5)] for future in as_completed(futu
res): print(future.result())
任务中抛出的异常会在调用 result() 时重新抛出,建议用 try-except 包裹:
try:
result = future.result(timeout=3) # 可设置超时
except Exception as e:
print(f"任务执行出错: {e}")
基本上就这些。submit 是在线程池中调度任务的核心方法,配合 Future 可实现灵活的异步控制。