プログラムとか 思ったこととか 徒然ブログ 投稿一覧へ戻る

タグ "thread" が付いている投稿一覧

【 Using Asyncio in Python 】Python における asyncio を利用した非同期プログラム ( asynchronous programming ) の勉強を継続する前に、今一度スレッド ( thread ) についてのちょっとした復習ノート、まとめてみた

Tags: python , thread , asyncio , asynchronous programming

Published 2020年10月11日19:42 by T.Tsuyoshi

スレッドは OS によって提供されている機能で、プログラムの一部を並行実行するようにするものです。 OS は、マシン上で同時に動作している他のプログラムも含めて、複数のスレッドにどのように CPU リソースを割り当てるか、を決定します。 「スレッドを使うべきではない」と書いている asyncio 関連の本も沢山あるようですが、物事はそれほど単純ではありません。 長所、短所を見極める必要があるのは当然のことです。 Asyncio はスレッドの代替選択肢として採用されました。ですから、ある程度の比較無しには asyncio 本来の価値を見極めることは困難です。 また、asyncio を利用するときでさえ、threads や processes を考慮しなけばいけない状況は多々あります。 …

【 Effective Python, 2nd Edition 】スレッド ( thread ) とコルーチン ( coroutine ) を混在させながら、asyncio を利用した非同期プログラムへ段階的に移行させよう!

Tags: Effective , python , thread , coroutine , asyncio

Published 2020年10月1日21:36 by T.Tsuyoshi

前回の記事 では、ブロッキング I/O ( blocking I/O ) とスレッド ( thread ) を利用して作成した TCP サーバー / クライアントプログラムを、コルーチン ( coroutine ) と …

【 Effective Python, 2nd Edition 】ブロッキング I/O ( blocking I/O ) とスレッド ( thread ) を利用しているプログラムを、asyncio 組み込みモジュールを利用してコルーチン ( coroutine ) と非同期 I/O ( asyncronous I/O ) を利用したプログラムにリファクタリング ( refactoring ) しよう!

Tags: Effective , python , thread , coroutine , asyncio , blocking io

Published 2020年9月27日22:00 by T.Tsuyoshi

さて、コルーチンを利用した fan-out、fan-in パターン実装を取り上げた記事 を読んで、「でも既存のプログラムをコルーチンを利用した非同期プログラムに移行するのは大変だ」という感想を持った方は多いようです。 Python には言語自体に非同期実行 ( asynchronous execution ) プログラムを記述するための仕様がスマートに組み込まれています。 それによって、スレッド ( thread ) を利用してブロッキング I/O ( blocking I/O …

【 Effective Python, 2nd Edition 】プログラムを並列処理 ( concurrency ) パターンへ移行するタイミングとツールを考えるシリーズ 第 3 回 - Thread インスタンスの頻繁な start / join による fan-out / fan-in パターン実装は避けるべし、の巻

Tags: Effective , refactoring , python , thread , concurrency , fan-out , fan-in

Published 2020年8月31日6:35 by T.Tsuyoshi

Python において I/O の並行実行を考えたときに真っ先に思い浮かぶのはスレッド ( thread ) だと思います。 しかしながら、fan-out を実現しようとして多数の並行実行ラインを作成した場合、スレッドの大きな弱点が顕わになってしまいます。 これを、前回までの coding challenge で実装した Conway's Game of Life プログラムを利用して考えていきます。 ( …

【 Effective Python, 2nd Edition 】Queue クラスを利用した producer-consumer パイプライン ( pipelines ) を構築して、マルチスレッドシーケンス処理をエレガントに管理しよう! 並行実行 ( parallelism ) と並列処理 ( concurrency ) もついでにちゃんとイメージしよう!

Tags: Effective , python , thread , pipeline , concurrency , queue , parallelism , producer-consumer

Published 2020年8月21日16:25 by T.Tsuyoshi

唐突ですが、放牧飼いをしている乳牛を搾乳する手順を考えます。牛たちはもう搾乳室 ( パーラー ) の前に集まっています、良い子!! a: 搾乳室の入口を開けて1頭1頭牛を呼び込みます。 1: 乳頭の汚れを落とし、かつ、刺激します ( 泌乳ホルモン分泌のために )。 2: ミルカーを装着して搾乳します。 3: 搾乳が終了したら乳頭にディッピング ( 消毒のようなものです ) をします。 …