首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python多进程:定制进程池

Python多进程:定制进程池
EN

Stack Overflow用户
提问于 2009-04-11 21:53:56
回答 3查看 5.3K关注 0票数 7

我正在将Process类继承为一个我称为EdgeRenderer的类。我想使用multiprocessing.Pool,除非我希望它们成为我的EdgeRenderer的实例,而不是常规进程。有可能吗?多么?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-04-12 14:24:47

来自杰西·诺勒的话:

接口目前不支持它,但这将是一个不错的补充。我将在本周将其添加到python2.7/2.6.3 3.1中

票数 3
EN

Stack Overflow用户

发布于 2016-12-02 02:50:07

这似乎起作用了:

代码语言:javascript
复制
import multiprocessing as mp

ctx = mp.get_context()  # get the default context

class MyProcess(ctx.Process):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        print("Hi, I'm custom a process")

ctx.Process = MyProcess  # override the context's Process

def worker(x):
    print(x**2)

p = ctx.Pool(4)
nums = range(10)
p.map(worker, nums)
票数 3
EN

Stack Overflow用户

发布于 2009-04-12 01:26:07

我在API中看不到它的任何挂钩。你也许可以通过使用initializerinitargs参数来复制你想要的功能。或者,您可以将该功能构建到用于映射的callable对象中:

代码语言:javascript
复制
class EdgeRenderTask(object):
    def op1(self,*args):
        ...
    def op2(self,*args):
        ...
p = Pool(processes = 10)
e = EdgeRenderTask()
p.apply_async(e.op1,arg_list)
p.map(e.op2,arg_list)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/740844

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档