10.6.3 按任意顺序等待任务
调用Future的result()方法会阻塞,知道任务完成(可能返回一个值,也可能抛出一个异常)或者撤销。可以使用map()按调度任务的顺序访问多个任务的结果。如果处理结果的顺序不重要,则可以使用as_completed()在每个任务完成时处理它的结果。
from concurrent import futures
import random
import time
def task(n):
time.sleep(random.random())
return (n,n / 10)
ex = futures.ThreadPoolExecutor(max_workers=5)
print('main:starting')
wait_for = [
ex.submit(task,i)
for i in range(5,0,-1)
]
for f in futures.as_completed(wait_for):
print('main:result: {}'.format(f.result()))
因为池中的工作新安村与任务同样多,故而所有任务都可以启动。它们会按随机的顺序完成,所以每次运行这个示例程序时as_completed()生成的值都不同。
运行结果: