首页 > 后端开发 > Python教程 > 如何在Python中的多个进程之间共享结果队列?

如何在Python中的多个进程之间共享结果队列?

Susan Sarandon
发布: 2024-10-19 18:45:02
原创
741 人浏览过

How to Share a Result Queue Between Multiple Processes in Python?

如何在多个进程之间共享结果队列

使用 multiprocessing 模块的 apply_async 处理异步工作进程时() 函数中,重要的是要考虑如何安全地共享队列。错误“RuntimeError:队列对象只能通过继承在进程之间共享”突出显示需要以防止 pickling/unpickling 问题的方式传递队列。

要解决此问题,我们可以利用 multiprocessing.Manager () 类,它提供了一种管理对象并使它们可供不同工作人员访问的方法。

<code class="python">import multiprocessing

def worker(name, que):
    que.put("%d is done" % name)

if __name__ == '__main__':
    pool = multiprocessing.Pool(processes=3)
    m = multiprocessing.Manager()
    q = m.Queue()
    workers = pool.apply_async(worker, (33, q))</code>
登录后复制

在此示例中,我们创建一个 Manager 对象 (m) 并使用它来管理队列(q)。通过这样做,我们创建了一个共享内存段,即使在异步场景中,该共享内存段也允许多个进程安全地访问队列。

以上是如何在Python中的多个进程之间共享结果队列?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板