アフィリエイト広告を利用しています

広告

posted by fanblog

2018年06月14日

《その402》マルチスレッド と mutexクラス


 マルチスレッド と mutexクラス

 例えば、スレッド th1 での cout による画面出力のコードを比較してみると、
 前回《401》のプログラムでは、
   cout << "th1 ・・・" + to_string(i + 1) + "回目\n";
となっていますから、一つにまとめられた文字列を一気に出力しています。
 一方、今回は、、
   cout << "th1 ・・・" << i + 1 << "回目\n";
と、"th1 ・・・", i + 1, "回目\n" の3回に分けて出力しています。

 そのため、本来、この3回の出力は連続して実行されるべきなのに、
非同期並列処理では相手のスレッドの状況が考慮されないため、スレッド th2 からの出力が途中に割り込んでしまう可能性があります。
今回の例でも、実際、割り込みが起きて出力が乱れています。
 cout は、2つのスレッドから同時に書き込まれることを想定していないのです。
次のプログラムの出力結果は、そのことを示しています。

 以下は、プログラムと出力結果です。

#include <iostream>
#include <thread>
#include <string>

using namespace std;

int main() {
thread th1 = thread([] {
for (int i = 0; i < 6; i++) {
cout << "th1 ・・・"
<< i + 1 << "回目\n";
}
});

thread th2 = thread([] {
for (int i = 0; i < 6; i++) {
cout << "th21 ・・・"
<< i + 1 << "回目\n";
}
});

th1.join();
th2.join();
}

add_d231.png

add_d232.png



 mutexクラスを用いて、この問題を解決することができます。
複数のスレッドから同じリソースを利用する際に、mutex の lock関数をを使うことでリソースの使用を制限することができます。

 今回の例のような cout による文字出力で生じる問題を解決する手段の一つとして、
次のようにして cout を必要な期間だけ排他にします。
  mutexクラスオブジェクト mtx を作成します(オブジェクト名は任意)。
  lock関数で、一定期間 cout を排他にします。
     mtx.lock();
     cout << "th1 ・・・" << i + 1 << "回目\n";

  unlock関数で、ロックを解除します。
     mtx.unlock();

 このようにすることで、他のスレッドから邪魔されることなく、一連の出力を行うことが可能になります。

 以下は、プログラムと出力結果です。

#include <iostream>
#include <thread>
#include <string>
#include <mutex>
using namespace std;

mutex mtx;

int main() {
thread th1 = thread([] {
for (int i = 0; i < 6; i++) {
mtx.lock();
cout << "th1 ・・・"
<< i + 1 << "回目\n";
mtx.unlock();
}
});

thread th2 = thread([] {
for (int i = 0; i < 6; i++) {
mtx.lock();
cout << "th2 ・・・"
<< i + 1 << "回目\n";
mtx.unlock();
}
});

th1.join();
th2.join();
}

add_d233.png

add_d234.png



この記事へのコメント
コメントを書く

お名前:

メールアドレス:


ホームページアドレス:

コメント:

※ブログオーナーが承認したコメントのみ表示されます。

この記事へのトラックバックURL
https://fanblogs.jp/tb/7778442
※ブログオーナーが承認したトラックバックのみ表示されます。

この記事へのトラックバック

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


検索
<< 2018年08月 >>
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
プロフィール
こうすけさんの画像
こうすけ

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


×

この広告は30日以上新しい記事の更新がないブログに表示されております。