为什么我在使用multiprocessing.Pool时遇到异常?

时间:2012-12-01 06:18:29

标签: python multiprocessing

这是我的代码:

import multiprocessing

class Worker:
    def run(self, msg):
        print '%s, it works!' % msg

def start_process():
    print 'Starting',multiprocessing.current_process().name

if __name__=='__main__':
    pool = multiprocessing.Pool(processes=2, initializer=start_process,)
    pool.apply_async(Worker().run, args=('congbo',))
    pool.close()
    pool.join()

但我在控制台中遇到异常:

Starting PoolWorker-1
Starting PoolWorker-2
Exception in thread Thread-2:
Traceback (most recent call last):
  File "/usr/lib/python2.7/threading.py", line 551, in __bootstrap_inner
    self.run()
  File "/usr/lib/python2.7/threading.py", line 504, in run
    self.__target(*self.__args, **self.__kwargs)
  File "/usr/lib/python2.7/multiprocessing/pool.py", line 319, in _handle_tasks
    put(task)
PicklingError: Can't pickle <type 'instancemethod'>: attribute lookup __builtin__.instancemethod failed

我刚将一个class.func传递给了pool.apply_async(),但我得到了异常。 任何人都可以告诉我如何将class.func传递给pool.apply_async(),3x !!!

1 个答案:

答案 0 :(得分:3)

作为类的一部分的函数不称为函数,它们被称为方法,并且您不能将对象实例的方法传递给apply_async(),您需要使用函数。

这样做的原因是multiprocessing完全是关于多个进程中的事情,当你传递一个实例方法时,你传递的是一个对象的一部分。并且该对象仅存在于其中一个进程中,因此其他进程无法访问它。

更改您的

class Worker:
    def run(self, msg):
        print '%s, it works!' % msg

def run(msg):
    print '%s, it works!' % msg

并使用它,它应该工作。