在Python中,可以使用concurrent.futures
模块来实现多线程并获取返回值。具体步骤如下:
concurrent.futures
模块:import concurrent.futures
def task():
# 执行任务
return result
executor = concurrent.futures.ThreadPoolExecutor()
future = executor.submit(task)
result()
方法获取返回值:result = future.result()
完整示例代码如下:
import concurrent.futures
def task():
# 执行任务
return result
executor = concurrent.futures.ThreadPoolExecutor()
future = executor.submit(task)
result = future.result()
print(result)
注意:future.result()
方法是一个阻塞方法,会等待任务执行完毕并返回结果。如果任务没有执行完毕,调用该方法会阻塞当前线程。如果需要并发执行多个任务并获取所有结果,可以使用as_completed()
方法和executor.map()
方法。