第十章:使用进程、线程和协程提供并发性-concurrent.futures:管理并发任务池-按任意顺序等待任务

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()生成的值都不同。
运行结果:
在这里插入图片描述

©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页