Mam bitowego kodu Pythona, który wygląda tak:Znalezienie wyjątek w Pythonie 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)
działa poprawnie kiedy ustawić flagę serial
, ale daje następujący błąd, gdy używany jest Pool
. Kiedy próbuję drukować coś od do_experiment
nic się nie pokazuje, więc nie mogę spróbować/złapać tam i wydrukować ślad stosu.
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
Co to dobry sposób, aby przejść debugowania to?
Prawdopodobnie to nie ma znaczenia, ale jaka jest wartość zwracana przez 'cpu_count()'? – mgilson
Zależy od systemu.2 na moim własnym laptopie 8. Na każdym z nich, czy 'pool.map' jest używany zamiast 'map', rzeczy się zrywają – noio