首页 > 后端开发 > Python教程 > 如何从 multiprocessing.Process 函数中检索返回值?

如何从 multiprocessing.Process 函数中检索返回值?

Patricia Arquette
发布: 2024-11-29 06:30:12
原创
851 人浏览过

How to Retrieve Return Values from multiprocessing.Process Functions?

如何从传递给 multiprocessing.Process 的函数中检索返回值

将函数传递给 multiprocessing.Process 时,通常需要检索函数的返回值。但是,这些值在返回的 Process 对象中不容易访问。

请考虑以下代码:

import multiprocessing

defworker(procnum):

'''worker function'''
print str(procnum) + ' represent!'
return procnum

登录后复制

如果名字== '__main__':

jobs = []
for i in range(5):
    p = multiprocessing.Process(target=worker, args=(i,))
    jobs.append(p)
    p.start()

for proc in jobs:
    proc.join()
print jobs
登录后复制

预期的返回值无法通过 'jobs' 中的 Process 对象获得。

解决方案:使用共享变量

为了检索返回值,可以利用共享变量来启用主进程和工作进程之间的通信

导入多处理

defworker(procnum, return_dict):

"""worker function"""
print(str(procnum) + " represent!")
return_dict[procnum] = procnum

登录后复制

if 名称 == "__main__":

manager = multiprocessing.Manager()
return_dict = manager.dict()
jobs = []
for i in range(5):
    p = multiprocessing.Process(target=worker, args=(i, return_dict))
    jobs.append(p)
    p.start()

for proc in jobs:
    proc.join()
print(return_dict.values())
登录后复制

解释:

  • 多处理管理器用于创建共享字典“return_dict”。
  • 每个工作进程访问共享的“return_dict”并将其返回值存储在其进程号下key。
  • 主进程通过访问字典的值来检索返回值。

以上是如何从 multiprocessing.Process 函数中检索返回值?的详细内容。更多信息请关注PHP中文网其他相关文章!

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