Value、Array是通过共享内存的方式共享数据
Manager是通过共享进程的方式共享数据。
队列直接插入元祖,对象也是可以的:event需要是manager的,这个对象可以在多个进程里面共享
em = SBD_msg(cam_no, frame, event_obj)
mlock.acquire()
data_queue.put(em)
Value\Array
实例代码:
import multiprocessing
#Value/Array
def func1(a,arr):
a.value=3.14
for i in range(len(arr)):
arr[i]=-arr[i]
if __name__ == '__main__':
num=multiprocessing.Value('d',1.0)#num=0
arr=multiprocessing.Array('i',range(10))#arr=range(10)
p=multiprocessing.Process(target=func1,args=(num,arr))
p.start()
p.join()
print num.value
print arr[:]
执行结果:
3.14
[0, -1, -2, -3, -4, -5, -6, -7, -8, -9]
Manager管理的共