pythonclass全局变量_Python-多处理全局变量更新未返回给父级

我正在尝试从子流程中返回值,但是不幸的是这些值无法拾取。因此,我在线程模块中成功使用了全局变量,但在使用多处理模块时却无法检索在子流程中完成的更新。我希望我想念一些东西。

在给定var 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 instantiations

def 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]:

这是我使用multiprocessing.Pool将实例返回给父对象时返回的错误:

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 objects

In [5]: dir(lorr)

Out[5]:

['GET_AMBIENT_TEMPERATURE',

'GET_CAN_ERROR',

'GET_CAN_ERROR_COUNT',

'GET_CHANNEL_NUMBER',

'GET_COUNT_PER_C_OP',

'GET_COUNT_REMAINING_OP',

'GET_DCM_LOCKED',

'GET_EFC_125_MHZ',

'GET_EFC_COMB_LINE_PLL',

'GET_ERROR_CODE_LAST_CAN_ERROR',

'GET_INTERNAL_SLAVE_ERROR_CODE',

'GET_MAGNITUDE_CELSIUS_OP',

'GET_MAJOR_REV_LEVEL',

'GET_MINOR_REV_LEVEL',

'GET_MODULE_CODES_CDAY',

'GET_MODULE_CODES_CMONTH',

'GET_MODULE_CODES_DIG1',

'GET_MODULE_CODES_DIG2',

'GET_MODULE_CODES_DIG4',

'GET_MODULE_CODES_DIG6',

'GET_MODULE_CODES_SERIAL',

'GET_MODULE_CODES_VERSION_MAJOR',

'GET_MODULE_CODES_VERSION_MINOR',

'GET_MODULE_CODES_YEAR',

'GET_NODE_ADDRESS',

'GET_OPTICAL_POWER_OFF',

'GET_OUTPUT_125MHZ_LOCKED',

'GET_OUTPUT_2GHZ_LOCKED',

'GET_PATCH_LEVEL',

'GET_POWER_SUPPLY_12V_NOT_OK',

'GET_POWER_SUPPLY_15V_NOT_OK',

'GET_PROTOCOL_MAJOR_REV_LEVEL',

'GET_PROTOCOL_MINOR_REV_LEVEL',

'GET_PROTOCOL_PATCH_LEVEL',

'GET_PROTOCOL_REV_LEVEL',

'GET_PWR_125_MHZ',

'GET_PWR_25_MHZ',

'GET_PWR_2_GHZ',

'GET_READ_MODULE_CODES',

'GET_RX_OPT_PWR',

'GET_SERIAL_NUMBER',

'GET_SIGN_OP',

'GET_STATUS',

'GET_SW_REV_LEVEL',

'GET_TE_LENGTH',

'GET_TE_LONG_FLAG_SET',

'GET_TE_OFFSET_COUNTER',

'GET_TE_SHORT_FLAG_SET',

'GET_TRANS_NUM',

'GET_VDC_12',

'GET_VDC_15',

'GET_VDC_7',

'GET_VDC_MINUS_7',

'SET_CLEAR_FLAGS',

'SET_FPGA_LOGIC_RESET',

'SET_RESET_AMBSI',

'SET_RESET_DEVICE',

'SET_RESYNC_TE',

'STATUS',

'_HardwareDevice__componentName',

'_HardwareDevice__hw',

'_HardwareDevice__stickyFlag',

'_LORRBase__logger',

'__del__',

'__doc__',

'__init__',

'__module__',

'_devices',

'clearDeviceCommunicationErrorAlarm',

'getControlList',

'getDeviceCommunicationErrorCounter',

'getErrorMessage',

'getHwState',

'getInternalSlaveCanErrorMsg',

'getLastCanErrorMsg',

'getMonitorList',

'hwConfigure',

'hwDiagnostic',

'hwInitialize',

'hwOperational',

'hwSimulation',

'hwStart',

'hwStop',

'inErrorState',

'isMonitoring',

'isSimulated']

In [6]:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值