[英]Multiprocessing Pool inside Process time out
当我使用以下代码时,池结果总是返回超时,我在做什么逻辑上不正确?
from multiprocessing import Pool, Process, cpu_count
def add(num):
return num+1
def add_wrap(num):
new_num = ppool.apply_async(add, [num])
print new_num.get(timeout=3)
ppool = Pool(processes=cpu_count() )
test = Process(target=add_wrap, args=(5,)).start()
我知道这个bug ,并且会认为它会在python 2.6.4中得到修复吗?
您无法在进程之间传递Pool对象。
如果您尝试此代码,Python将引发异常:'NotImplementedError:池对象不能在进程之间传递或被pickle'。
from multiprocessing import Queue, Pool
q = Queue()
ppool = Pool(processes=2)
q.put([ppool])
ppool = q.get()
因此,如果您希望代码工作,只需在add_wrap方法中创建Pool对象即可。
from multiprocessing import Pool, Process, cpu_count
def add(num):
return num+1
def add_wrap(num):
ppool = Pool(processes=cpu_count() )
new_num = ppool.apply_async(add, [num])
print new_num.get(timeout=3)
test = Process(target=add_wrap, args=(5,)).start()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.