6

私は次のようなPythonコードを少し持っています:

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)

serialフラグを設定すると正常に動作しますが、Poolを使用すると次のエラーが発生します。何もないところから何かを印刷しようとするとdo_experiment表示されないので、そこで試行/キャッチしてスタックトレースを印刷することはできません。

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

これのデバッグを続行するための良い方法は何ですか?

4

1 に答える 1

17

物事がまだ機能しているコミットが見つかるまで、git履歴に戻りました。

dictキーにアクセスできるように拡張するクラスをコードに追加しました.(したがってdict.foo、代わりにdict["foo"]. Multiprocessing はこれに親切に対応しませんでした。通常の dict を使用して問題を解決しました。

于 2012-05-31T09:47:54.900 に答える