gpt4 book ai didi

python-3.x - Py3.6::ThreadPoolExecutor future.add_done_callback 与 concurrent.futures.as_completed

转载 作者:行者123 更新时间:2023-12-05 06:30:43 27 4
gpt4 key购买 nike

我在学习concurrent.futures.ThreadPoolExecutor在 Py3.6 中,对于使用之间的区别、优缺点有点困惑

1 future.add_done_callback(callback)

2 concurrent.futures.as_completed(futures)

您什么时候会选择一个而不是另一个?如果我理解正确的话,两者的目的或多或少是相同的。#1 在任务完成并且相应的 future 已经解决后立即调用 callback(future) fn,#2 按照任务完成和 future 结算的顺序返回 future 对象..

在这两种情况下,我们都可以使用 future.results() 检索返回值(如果引发异常,则引发 future.exception())。

感谢您对此的任何澄清。

最佳答案

函数的定义在https://github.com/python/cpython/blob/f85af035c5cb9a981f5e3164425f27cf73231b5f/Lib/concurrent/futures/_base.py#L200

def as_completed(fs, timeout=None):
"""An iterator over the given futures that yields each as it completes.

add_done_callback 是 futures 类中的一个方法,是比 as_completed 更低级别的函数。本质上,as_completed 在内部使用 add_done_callback。 as_completed 也有回调的超时参数。一般来说,如果处理多个 future,我们可以使用 as_completed,而 add_done_callback 用于单个 future。总的来说,对于更简单的程序,add_done_callback 和 as_completed 都可以实现类似的目标。

只是一个想法。我们可以使用 add_done_callback 为 future 列表中的每个 future 使用不同的回调函数,而 as_completed 可能只接受一个单一的回调。

关于python-3.x - Py3.6::ThreadPoolExecutor future.add_done_callback 与 concurrent.futures.as_completed,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52131725/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com