Я хочу добавить список dicts вместе с модулем многопроцессорности python.проблема блокировки многопроцессорности python
Вот упрощенная версия моего кода:
#!/usr/bin/python2.7
# -*- coding: utf-8 -*-
import multiprocessing
import functools
import time
def merge(lock, d1, d2):
time.sleep(5) # some time consuming stuffs
with lock:
for key in d2.keys():
if d1.has_key(key):
d1[key] += d2[key]
else:
d1[key] = d2[key]
l = [{ x % 10 : x } for x in range(10000)]
lock = multiprocessing.Lock()
d = multiprocessing.Manager().dict()
partial_merge = functools.partial(merge, d1 = d, lock = lock)
pool_size = multiprocessing.cpu_count()
pool = multiprocessing.Pool(processes = pool_size)
pool.map(partial_merge, l)
pool.close()
pool.join()
print d
Я получаю эту ошибку при запуске этого сценария. Как я могу это решить?
RuntimeError: Lock objects should only be shared between processes through inheritance
в
merge
функции, необходимые в этом состоянииlock
? или python позаботится об этом?Я думаю, что
map
должен сделать что-то из одного списка в другой список, а не сбрасывать все вещи в одном списке на один объект. Так есть ли более элегантный способ сделать такие вещи?