[解決済み] 複数のプロセスで結果待ち行列を共有する
2022-10-23 17:56:19
質問
のドキュメントは
multiprocessing
モジュールで開始されたプロセスにキューを渡す方法を示しています。
multiprocessing.Process
. で起動される非同期ワーカープロセスとキューを共有するにはどうすればよいのでしょうか?
apply_async
? 私は動的結合やその他のものを必要とせず、ワーカーが(繰り返し)結果をベースに報告する方法だけです。
import multiprocessing
def worker(name, que):
que.put("%d is done" % name)
if __name__ == '__main__':
pool = multiprocessing.Pool(processes=3)
q = multiprocessing.Queue()
workers = pool.apply_async(worker, (33, q))
で失敗します。
RuntimeError: Queue objects should only be shared between processes through inheritance
.
これが何を意味するかは理解していますし、pickling/unpicklingを要求するよりも継承したほうがいいというアドバイスも理解しています(そして、Windowsの特別な制限もすべて)。しかし、どのように
を行うのでしょうか。
キューを動作する方法で渡すことができますか? 私は例を見つけることができず、いくつかの代替案を試しましたが、さまざまな方法で失敗しました。助けてください。
どのように解決するのですか?
以下の方法で試してみてください。 マルチプロセッシング・マネージャー を使ってキューを管理し、異なるワーカーからアクセスできるようにします。
import multiprocessing
def worker(name, que):
que.put("%d is done" % name)
if __name__ == '__main__':
pool = multiprocessing.Pool(processes=3)
m = multiprocessing.Manager()
q = m.Queue()
workers = pool.apply_async(worker, (33, q))
関連
-
[解決済み] と'is'のどちらかを使って文字列を比較すると、異なる結果になることがあるのはなぜですか?
-
[解決済み] JavaScriptでStackとQueueを実装するには?
-
[解決済み] SQLAlchemy: セッションの作成と再利用
-
[解決済み] Flaskで1時間ごとに関数を実行するようにスケジュールするには?
-
[解決済み] 辞書のキーと値を交換するにはどうすればよいですか?
-
[解決済み] 古いバージョンのPythonにおける辞書のキーの並び順
-
[解決済み] Cythonのコードを含むPythonパッケージはどのように構成すればよいのでしょうか?
-
[解決済み] PyQtアプリケーションのスレッド化。QtスレッドとPythonスレッドのどちらを使うか?
-
[解決済み] Pythonの文字列の前にあるbという接頭辞は何を意味するのですか?
-
[解決済み] Pythonの辞書にあるスレッドセーフについて
最新
-
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のキャッシュライブラリはありますか?
-
[解決済み] PythonからSMTPを使用してメールを送信する
-
[解決済み] Python Logging でログメッセージが2回表示される件
-
[解決済み] CSVデータを処理する際、1行目のデータを無視する方法を教えてください。
-
[解決済み] djangoフレームワークでフォームフィールドから値を取得するには?
-
[解決済み] Python 言語を決定するには?
-
[解決済み] 単純な文字列からtimedeltaオブジェクトを作成する方法
-
[解決済み] Django filter queryset __in for *every* item in list
-
[解決済み] 新しいpip backtrackingの実行時問題の解決
-
[解決済み] Pythonでリストが空かどうかをチェックする方法は?重複