您的位置:首页 > 娱乐 > 明星 > python并行计算之pool.apply_async()与pool.imap()的异同点

python并行计算之pool.apply_async()与pool.imap()的异同点

2024/10/5 22:29:16 来源:https://blog.csdn.net/weixin_46713695/article/details/141917487  浏览:    关键词:python并行计算之pool.apply_async()与pool.imap()的异同点

目录

      • 1. 框架和技术概要: 🎨🖥️
      • 2. 相似点: 🧩💡
      • 3. 不同点: 📊👣
      • 4. 使用示例: 😊👨‍💻
      • 5. 总结: 🎉

1. 框架和技术概要: 🎨🖥️

multiprocessing 模块中的 pool.apply_async()pool.imap() 都用于并行处理,但它们在使用方式和返回结果上有所不同。

2. 相似点: 🧩💡

  1. 并行处理: 两者都用于在多个进程中并行执行函数。
  2. 适用于多核处理: 都可以充分利用多核 CPU 来加速计算。

3. 不同点: 📊👣

特性pool.apply_async()pool.imap()
返回类型返回一个 AsyncResult 对象,可以通过 get() 方法获取结果返回一个迭代器,可以逐个获取结果
执行方式提交任务并立即返回,适合独立任务适合处理可迭代对象中的每个元素,按顺序返回结果
阻塞行为不会阻塞主线程,可以同时提交多个任务迭代器会按顺序阻塞,直到结果可用
错误处理可通过 AsyncResult 对象捕获异常迭代器会在遍历时抛出异常

4. 使用示例: 😊👨‍💻

  1. pool.apply_async():
from multiprocessing import Pooldef square(x):return x * xwith Pool(processes=4) as pool:results = [pool.apply_async(square, (i,)) for i in range(10)]output = [result.get() for result in results]print(output)

pool = multiprocessing.Pool(processes=5)
results, processes = [], []
for file_path in ans_file_paths:processes.append(pool.apply_async(cal_max_speed, args=(file_path,)))
for processe in tqdm(processes):results.append(processe.get())
pool.close()
pool.join()
  1. pool.imap():
from multiprocessing import Pooldef square(x):return x * xwith Pool(processes=4) as pool:output = pool.imap(square, range(10))print(list(output))

或者

with multiprocessing.Pool(processes=processes) as pool:results = list(tqdm(pool.imap(cal_max_speed, file_generator(root_dir, ids_set)),total=len(ids_set)))  

5. 总结: 🎉

  • 如果需要立即提交多个独立任务,并在之后获取结果,可以使用 apply_async()
  • 如果处理的是一个可迭代对象,并希望按顺序获取结果,imap() 是更好的选择。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com