首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MultiProcessing与self.methods

MultiProcessing与self.methods
EN

Stack Overflow用户
提问于 2016-11-22 16:05:49
回答 1查看 3.5K关注 0票数 2

在方法上使用multiprocessing,我们得到了错误声明self.methods cannot be pickled

为了克服这个问题,我用了:

代码语言:javascript
复制
def _pickle_method(m):
    if m.im_self is None:
        return getattr, (m.im_class, m.im_func.func_name)
    else:
        return getattr, (m.im_self, m.im_func.func_name)


copy_reg.pickle(types.MethodType, _pickle_method)

现在我搜索了一下,但很少有问题还不清楚:

  1. 为什么self.methods不能被腌制?
  2. copy_reg.pickle()是如何工作的?如何使self.methods进行酸洗
  3. 使用这种方法有什么负面影响,还是有其他更好的方法?

更多信息:

我在一个类中有一个函数,它曾经做过一个request.getrequest.post。为了改善时间,我在上面使用了multiprocessing。这正是我所面临的问题。

Can't pickle when using multiprocessing Pool.map()

EN

回答 1

Stack Overflow用户

发布于 2016-11-22 18:51:18

您的预期用法仍然有点模糊,因此我将在您问题的新的“更多信息”部分展示一种解决linked question的方法,该部分不需要对类方法的字节代码进行筛选。我觉得很明显.

someclass.py

代码语言:javascript
复制
import multiprocessing

def call_method(x):
    return SomeClass().f(x)

class SomeClass(object):
    def __init__(self):
        pass

    def f(self, x):
        return x*x

    def go(self):
        pool = multiprocessing.Pool(processes=4)
        print(pool.map(call_method,  range(10)))
        pool.close()

test.py

代码语言:javascript
复制
import someclass

if __name__== '__main__' :
    sc = someclass.SomeClass()
    sc.go()

输出:

代码语言:javascript
复制
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40746507

复制
相关文章

相似问题

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