c++11マルチスレッドプログラミング--原子
1279 ワード
以下は私のc++11マルチスレッドのプログラミングについての学習の体得で、みんなが多く指摘することを望みます
目的:1原子型の導入は、追加の同期機構を必要とせずに同時読み書き操作を実行できることを意味する.
2原子操作は確かに共有データによる問題を解決する有効な手段とすることができる.
例:(コードはVS 2015でコンパイル済み)
複数回プログラムを実行した結果、Result=1002となった.
例を挙げると、単純なデータ型に対して共有が必要な場合、原子型を使用すると、表示されないロックを追加した場合、デッドロックと競合条件を回避することができます->複数のスレッドが共有領域に同時にアクセスすることを防止することができます.
原子操作:
total2._My_val = 3;
total2.store(13);//原子のvalueを13に設定
int total1 = total2.load();//原子を取得するvalue
目的:1原子型の導入は、追加の同期機構を必要とせずに同時読み書き操作を実行できることを意味する.
2原子操作は確かに共有データによる問題を解決する有効な手段とすることができる.
例:(コードはVS 2015でコンパイル済み)
// test_atomic_1.cpp : 。
#include "stdafx.h"
#include
#include
#include
#include
void fun(std::atomic_int &total)
{
for (size_t i = 0; i < 1000; i++)
{
++total;
}
}
int main()
{
std::atomic_int total(12);
std::atomic_int total2 = 0;
total2._My_val = 3;
total2.store(13);
int total1 = total2.load();;
std::atomic_int total(12);
int total1 = 12;
std::vector<:thread> threads;
for (size_t i = 0; i < 10; i++)
{
threads.push_back(std::thread{ fun,std::ref(total) });
}
for (auto&tan : threads)
{
tan.join();
}
std::cout << "Result=" << total << std::endl;
return 0;
}
複数回プログラムを実行した結果、Result=1002となった.
例を挙げると、単純なデータ型に対して共有が必要な場合、原子型を使用すると、表示されないロックを追加した場合、デッドロックと競合条件を回避することができます->複数のスレッドが共有領域に同時にアクセスすることを防止することができます.
原子操作:
total2._My_val = 3;
total2.store(13);//原子のvalueを13に設定
int total1 = total2.load();//原子を取得するvalue