Python プログラミング

Python3でマルチスレッド処理を試してみる

Pythonでマルチスレッド処理をさせたいと思ったので、具体的な方法を調べて試してみました。

マルチスレッドで処理させるには、どうやら大きく2つの方法があるらしいです。せっかくなので、勉強のために今回は両方で試してみます。ちなみにPython3での実装です。

方法1:Threadクラスを継承する

まず1つ目の方法は、threading.Threadクラスを継承したクラスを作るという方法です。具体的なコードで書くとこんな感じ。

スレッド内で実行したい処理をrun関数内に実装してあげることがポイントです。今回は5秒間、1秒間隔でカウントアップする処理を実装しました。

メイン処理では、作成したクラスのインスタンスを2つ作り、それぞれstart関数で実行開始します。実行結果はこんな感じ。

[ryo@python] $ python3 thread.py
count 0
count 0
count 1
count 1
count 2
count 2
count 3
count 3
count 4
count 4

たしかにスレッド2つの処理が並行して走っていることが分かります。

方法2:Threadクラスのインスタンスを作る

2つめの方法は、Threadクラスのインスタンスを作る方法です。並列処理したい関数を引数に設定してthreading.Threadクラスのインスタンスを作ると、start関数で処理を走らせることができます。

こちらの実装でも実行結果は先ほどと変わりません。クラスを定義しなくてもいい分、こちらの方がお手軽かもしれません。

まとめ

どちらの方法でも割と簡単に並列処理を実装することができました。サブクラスを作るのかそれともインスタンスを作るのかはケースによって使い分けが必要そうですが、並列化したい処理の規模が小さければインスタンスの方がずっと簡単そうです。

今回はほんの触りだけだったので、もう少し深いところまで調べてみようと思います(・∀・)

ではではノシ

関連記事

Linux

2019/10/6

Docker + Growiでイントラ向けWikiを立ち上げる

チーム開発をしていくうえで、課題の1つになるのが情報共有です。チームの歴史が長いと経験値は溜まっていきますが、それらが情報として整理されていないとメンバー交代時などに大きなコストが発生します。 そこで、イントラ向けのナレッジベース(Wiki)を探していたところ、Growiという良さげなOSSを見つけたので、お試し環境を立ち上げてみることにしました。手元の環境はUbuntu18.04ですが、Linuxであれば大体同じような手順になると思います。 目次1 Dockerのインストール2 Growiの準備2.1 ...

この記事を読む

Linux

2019/8/14

カゴヤVPSで自分専用の開発環境を立ち上げてみた

どこからでもアクセスできる自分専用の開発環境が欲しい…。 そんな願いを叶えるべく、VPSのことを調べていたのですが、いままで「なんか難しそう…」と尻込みしていました。しかし、最近は値段も安くて扱いやすいVPSも増えてきたので、この機会に試してみることにしました。 ということで、今回はVPSを契約して最低限の環境を立ち上げるまでの備忘録です。 目次1 VPSについて1.1 VPSって何?1.2 カゴヤのVPSを契約してみた2 手順1:インスタンスを立ち上げる3 手順2:インスタンスにSSH接続する4 手順3 ...

この記事を読む

Windows

2019/5/5

Windows10で不要なブートエントリを削除する

Windowsのブートまわりで少しハマったので覚え書きです。 私のメインPCはWindows10とUbuntuのデュアルブートだったのですが、とある事情でUbuntuを削除しWindowsのみの構成に戻すことにしました。ちなみに、デュアルブート時の環境はこんな感じ(だったはず)。 元に戻したくなったときのことを考え、別HDD(ドライブB)にUbuntuとGRUBを入れ、GRUB経由でWindowsとUbuntuを立ち上げる形にしていました。 そのため、起動ドライブをWindowsのドライブ(ドライブA)に ...

この記事を読む

C言語 プログラミング

2018/12/25

mmapの下処理にftruncate関数を利用する

以前このブログで公開した記事の中に、C言語のmmap関数の使い方についてまとめた記事がありました。 Corgi Lab. ~備忘録のための技術ブログ~  3 shares 3 users 4 pocketsファイルの読み書きにmmapを使ってみるプログラムのループ中でファイルに何かしらのデータを書き込むとき、そのたびにwriteをしていたのではディスクへのI/Oが頻発してしまい、パフォーマンスに影響することがあります。「C言語だとそんなときはmmapを使うと良い」と ...

この記事を読む

Mac Linux

2018/12/2

Mac mini (2012) にUbuntu18.04をインストールしてみた

今年のアップデートにより、ついに旧型となってしまったMac mini(2012年モデル)。私の自宅にも箱に収められたままひっそりと眠るMac miniがありました。 約6年前のモデルと言うことで、最近のマシンから見ればスペック的に見劣りするPCになってしまいましたが、Linux機として運用するならまだまだ輝けるはず! ということで、今回はMac miniをUbuntu専用マシンとして復活させてみたので、その備忘録です。 目次1 用意するもの2 Ubuntuのインストール3 インストール後のセットアップ3. ...

この記事を読む

-Python, プログラミング

Copyright© Corgi Lab. ~備忘録のための技術ブログ~ , 2019 All Rights Reserved.