未返回给父级的多处理全局变量更新我试图从子进程返回值,但不幸的是,这些值是不可选择的。因此,我成功地在线程模块中使用了全局变量,但在使用多处理模块时无法检索子进程中完成的更新。我希望我错过了什么。在结尾处打印的结果总是与给定vars的初始值相同。dataDV03和dataDV04..子进程正在更新这些全局变量,但是这些全局变量在父进程中保持不变。import multiprocessing# NOT ABLE to get python to return values in passed variables.ants = ['DV03', 'DV04']dataDV03 = ['', '']dataDV04 = {'driver': '', 'status': ''}def getDV03CclDrivers(lib): # call global variable
global dataDV03
dataDV03[1] = 1
dataDV03[0] = 0# eval( 'CCL.' + lib + '.' + lib + '( "DV03" )' ) these are unpicklable instantiationsdef getDV04CclDrivers(lib, dataDV04): # pass global variable
dataDV04['driver'] = 0 # eval( 'CCL.' + lib + '.' + lib + '( "DV04" )' )if __name__ == "__main__":
jobs = []
if 'DV03' in ants:
j = multiprocessing.Process(target=getDV03CclDrivers, args=('LORR',))
jobs.append(j)
if 'DV04' in ants:
j = multiprocessing.Process(target=getDV04CclDrivers, args=('LORR', dataDV04))
jobs.append(j)
for j in jobs:
j.start()
for j in jobs:
j.join()
print 'Results:\n'
print 'DV03', dataDV03 print 'DV04', dataDV04我不能张贴到我的问题,所以将尝试编辑原件。以下是不可选择的对象:In [1]: from CCL import LORR
In [2]: lorr=LORR.LORR('DV20', None)
In [3]: lorr
Out[3]: <CCL.LORR.LORR instance at 0x94b188c>这是在使用多进程时返回的错误。池将实例返回给父进程:Thread getCcl (('DV20', 'LORR'),)
Process PoolWorker-1:
Traceback (most recent call last):
File "/alma/ACS-10.1/casa/lib/python2.6/multiprocessing/process.py", line 232, in _bootstrap
self.run()
File "/alma/ACS-10.1/casa/lib/python2.6/multiprocessing/process.py", line 88, in run
self._target(*self._args, **self._kwargs)
File "/alma/ACS-10.1/casa/lib/python2.6/multiprocessing/pool.py", line 71, in worker
put((job, i, result))
File "/alma/ACS-10.1/casa/lib/python2.6/multiprocessing/queues.py", line 366, in put
return send(obj)
UnpickleableError: Cannot pickle <type 'thread.lock'> objects
3 回答

烙印99
TA贡献1829条经验 获得超13个赞
import multiprocessingfrom multiprocessing import Managerants = ['DV03', 'DV04']def getDV03CclDrivers(lib, data_dict): data_dict[1] = 1 data_dict[0] = 0def getDV04CclDrivers(lib, data_list): data_list['driver'] = 0 if __name__ == "__main__": manager = Manager() dataDV03 = manager.list(['', '']) dataDV04 = manager.dict({'driver': '', 'status': ''}) jobs = [] if 'DV03' in ants: j = multiprocessing.Process( target=getDV03CclDrivers, args=('LORR', dataDV03)) jobs.append(j) if 'DV04' in ants: j = multiprocessing.Process( target=getDV04CclDrivers, args=('LORR', dataDV04)) jobs.append(j) for j in jobs: j.start() for j in jobs: j.join() print 'Results:\n' print 'DV03', dataDV03 print 'DV04', dataDV04
不可分离的数据
class LORRProxy(object): def __init__(self, lorrObject=None): self.instance = lorrObject def __getstate__(self): # how to get the state data out of a lorr instance inst = self.instance state = dict( foo = inst.a, bar = inst.b, ) return state def __setstate__(self, state): # rebuilt a lorr instance from state lorr = LORR.LORR() lorr.a = state['foo'] lorr.b = state['bar'] self.instance = lorr

一只斗牛犬
TA贡献1784条经验 获得超2个赞
shared_dataDV03 = multiprocessing.Array ('i', (0, 0)) #a shared array
j = multiprocessing.Process(target=getDV03CclDrivers, args=('LORR',shared_dataDV03))
def getDV03CclDrivers(lib,arr): # call global variable arr[1]=1 arr[0]=0
print 'DV03', shared_dataDV03[:]
DV03 [0, 1]
添加回答
举报
0/150
提交
取消