manager 能够实现进程之间的数据共享 (list,dict)

  如果多个进程同事修改同一份共享数据,这个时候需要加锁,保证数据的准确性。

  (1) dict list 可以实现进程之间的数据共享
  (2)为了保证数据的准确性,需要加锁

基本语法:

m = Manager()

dic = m.dic({"count":1000}) 或者 lst = m.list({"count":1000})

 from multiprocessing import Process,Manager,Lock
def work(dic,lock):
# with 语法 可以自动的上锁和解锁
with lock:
dic["count"] -= 1
"""
lock.acquire()
dic["count"] -= 1
lock.release()
""" if __name__ == '__main__':
lst = []
# 创建一把锁
lock = Lock()
m = Manager()
dic = m.dict({"count" : 1000}) for i in range(100):
p = Process(target=work,args=(dic,lock))
p.start()
lst.append(p) for i in lst:
i.join() print(dic,type(dic))
05-23 23:00