[解決済み] multiprocessing.Pool.joinはいつ呼び出すべきですか?
2022-08-28 07:22:44
質問
multiprocess.Pool.imap_unordered」を以下のように使用しています。
from multiprocessing import Pool
pool = Pool()
for mapped_result in pool.imap_unordered(mapping_func, args_iter):
do some additional processing on mapped_result
を呼び出す必要があるのでしょうか?
pool.close
または
pool.join
の後では?
どのように解決するのですか?
いいえ、そんなことはありません。しかし、もうプールを使用しないのであれば、その方がよいでしょう。
呼び出す理由
pool.close
または
pool.join
は、Tim Peters が次のように言っています。
この SO ポスト
:
Pool.close()については、Poolインスタンスにこれ以上作業を送信しないとき、そしてそのときだけ、それを呼び出す必要があります。つまり、Pool.close() は通常、メイン・プログラムの並列化可能な部分が終了したときに呼び出されます。そして、ワーカー・プロセスは、すでに割り当てられたすべての作業が完了したときに終了します。
ワーカー・プロセスが終了するのを待つためにPool.join()を呼び出すことも優れたプラクティスです。他の理由の中で、並列化されたコードで例外を報告する良い方法はしばしばありません (例外はメインプログラムが何をしているかに漠然と関連したコンテキストでのみ発生します)。そして Pool.join() は同期ポイントを提供し、そうしなければ決して見ることができないワーカープロセスで発生したいくつかの例外を報告することができるのです。
関連
-
[解決済み] プログラムの実行やシステムコマンドの呼び出しはどのように行うのですか?
-
[解決済み] for'ループでインデックスにアクセスする?
-
[解決済み] PandasでDataFrameの行を反復処理する方法
-
[解決済み] バイトを文字列に変換する
-
[解決済み] リストを均等な大きさの塊に分割するには?
-
[解決済み] Python 3で「1000000000000000 in range(1000000000000001)」はなぜ速いのですか?
-
[解決済み] モジュールの関数名(文字列)を使って、モジュールの関数を呼び出す。
-
[解決済み] Pythonでオブジェクトが属性を持つかどうかを知る方法
-
[解決済み] ローカルディレクトリからrequirements.txtファイルに従ってpipを使用してパッケージをインストールするにはどうすればよいですか?
-
[解決済み] DataFrameに日付間の日数カラムを追加する pandas
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] Pythonのマルチプロセッシングプールimap_unorderedの呼び出しの進捗を表示しますか?
-
[解決済み] Jupyterノートブックでenv変数を設定する方法
-
[解決済み] pandasのDataFrameから空のセルを含む行を削除する
-
[解決済み] 値で列挙名を取得する [重複]。
-
[解決済み] スペースがないテキストを単語のリストに分割する方法
-
[解決済み] Django 1.7で初期マイグレーションからマイグレートバックする方法は?
-
[解決済み] Pythonでファイルの読み込みと上書きをする
-
[解決済み] 単純な文字列からtimedeltaオブジェクトを作成する方法
-
[解決済み] あるメソッドが複数の引数のうち1つの引数で呼び出されたことを保証する
-
[解決済み] djangoのQueryDictをPythonのDictに変更するには?