python - 回调函数在多处理 map_async 中如何工作?

标签 python multiprocessing pool

调试代码花了我一晚上的时间,终于发现了这个棘手的问题。请看下面的代码。

from multiprocessing import Pool

def myfunc(x):
    return [i for i in range(x)]

pool=Pool()

A=[]
r = pool.map_async(myfunc, (1,2), callback=A.extend)
r.wait()

我以为我会得到 A=[0,0,1],但输出是 A=[[0],[0,1]]。这对我来说没有意义,因为如果我有 A=[]A.extend([0])A.extend([0,1 ]) 会给我A=[0,0,1]。回调可能以不同的方式工作。所以我的问题是如何获得 A=[0,0,1] 而不是 [[0],[0,1]]?

最佳答案

如果您使用 map_async,则会调用一次回调并返回结果 ([[0], [0, 1]])。

>>> from multiprocessing import Pool
>>> def myfunc(x):
...     return [i for i in range(x)]
... 
>>> A = []
>>> def mycallback(x):
...     print('mycallback is called with {}'.format(x))
...     A.extend(x)
... 
>>> pool=Pool()
>>> r = pool.map_async(myfunc, (1,2), callback=mycallback)
>>> r.wait()
mycallback is called with [[0], [0, 1]]
>>> print(A)
[[0], [0, 1]]

使用 apply_async如果您希望每次都调用回调。

pool=Pool()
results = []
for x in (1,2):
    r = pool.apply_async(myfunc, (x,), callback=mycallback)
    results.append(r)
for r in results:
    r.wait()

关于python - 回调函数在多处理 map_async 中如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19699165/

相关文章:

python - 如何使用 boto3 从名称中带有句点 (.) 的存储桶访问 key ?

c++ - waf:如何使用额外的工具以及如何分发项目?

python - Django模型的唯一字段值

python - multiprocessing.shared_memory 是否需要锁定?

java - tomcat jdbc连接池,使用后不释放连接

java - Hibernate池似乎释放了连接

database - Grails - 基于用户切换数据源

python - 了解tf.contrib.lite.TFLiteConverter量化参数

c - 多进程计算中如何保证结果的重复性

python - matplotlib 中的多进程绘图