Ho un po 'di codice Python che assomiglia a questo:eccezione Finding in python multiprocessing
procs = cpu_count()-1
if serial or procs == 1:
results = map(do_experiment, experiments)
else:
pool = Pool(processes=procs)
results = pool.map(do_experiment, experiments)
Funziona benissimo quando ho impostato il flag serial
, ma dà il seguente errore quando si utilizza il Pool
. Quando provo a stampare qualcosa da do_experiment
non compare nulla, quindi non posso provare/catturare lì e stampare una traccia dello stack.
Exception in thread Thread-2:
Traceback (most recent call last):
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/threading.py", line 530, in __bootstrap_inner
self.run()
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/threading.py", line 483, in run
self.__target(*self.__args, **self.__kwargs)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/multiprocessing/pool.py", line 285, in _handle_tasks
put(task)
TypeError: 'NoneType' object is not callable
Qual è un buon modo per eseguire il debug di questo?
Questo probabilmente non ha importanza, ma qual è il valore restituito da 'cpu_count()'? – mgilson
Dipende dal sistema 2 sul mio portatile 8 sul server. In entrambi i casi, se 'pool.map' viene utilizzato al posto di di 'map', le cose si rompono – noio