質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
並列処理

複数の計算が同時に実行される手法

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

3495閲覧

PythonでThreadPoolExecutorの片方が終わったらもう一方も終わらせたい

egnoi

総合スコア5

並列処理

複数の計算が同時に実行される手法

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

1グッド

0クリップ

投稿2022/07/13 17:58

前提

ThreadPoolExecutorを使って二つのプロセスを並列処理しています

実現したいこと

片方の処理が終了した時点で、もう一方の処理も中断してプログラムを終了させたいです

発生している問題・エラーメッセージ

下記のプログラムを実行して、exit()でプログラムを終了させることを期待していたのですが、終了しませんでした。
time_exit関数が終了した後もloop関数の出力が止まらず、time_exitが終了した時点でloop関数を終了させるためにはどうしたらよいか、ご教示いただけますと幸いです。
宜しくお願い致します。

該当のソースコード

Python

1import time 2from concurrent.futures import ThreadPoolExecutor 3 4def loop(): 5 while True: 6 print("hello") 7 time.sleep(1) 8 9def time_exit(): 10 print("time_exit") 11 time.sleep(5) 12 print("exit") 13 exit() 14 15print("start") 16executor = ThreadPoolExecutor(max_workers=2) 17executor.submit(time_exit) 18executor.submit(loop) 19executor.shutdown()

試したこと

「ThreadPoolExecutor 強制終了」などで検索して見たのですが、解決に至るような記事を見つけることができなかったため、お力をお借りしたく質問した次第です。

補足情報(FW/ツールのバージョンなど)

python 3.7.7

q22r5695👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

基本的に、スレッドやプロセスを外部から強制的に終了させるのはよくありません。
プロセスが終了するときには、掴んでいるリソースを解放したり、未保存のデータを保存したり、トランザクションを適切に中断するなど、終了する前にやっておくべきことがあるからです。

こういう場合、そのスレッド/プロセスと通信してそのプロセスに停止を要求する、のが定石です。
通信の方法にはいろいろありますが、スレッドであれば変数が共有できますから、以下のようにすればいいでしょう。
run_flagが共有されている変数で、片方で書き換えることで、もう一方が停止します。

python

1run_flag = True 2 3def loop(): 4 global run_flag 5 while run_flag: 6 print("hello") 7 time.sleep(1) 8 9def time_exit(): 10 global run_flag 11 print("time_exit") 12 time.sleep(10) 13 run_flag = False 14 print("exit")

通信の方法はいろいろあります。 「プロセス間通信」とかで検索してみてください。

投稿2022/07/14 05:51

TakaiY

総合スコア12765

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

egnoi

2022/07/14 13:24

TakaiY様、ありがとうございます。 プログラムまで付けて説明してくださり、大変参考になりました。 思い通りにプログラムを動かすことができました。 参考キーワードまで教えていただき、誠にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問