国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++11并發編程關于原子操作atomic的代碼示例

2020-05-23 13:22:51
字體:
來源:轉載
供稿:網友

一:概述

項目中經常用遇到多線程操作共享數據問題,常用的處理方式是對共享數據進行加鎖,如果多線程操作共享變量也同樣采用這種方式。

為什么要對共享變量加鎖或使用原子操作?如兩個線程操作同一變量過程中,一個線程執行過程中可能被內核臨時掛起,這就是線程切換,當內核再次切換到該線程時,之前的數據可能已被修改,不能保證原子操作。

C++11提供了個原子的類和方法atomic,保證了多線程對變量原子性操作,相比加鎖機制mutex.lock(),mutex.unlock(),性能有幾倍的提升。

所需頭文件<atomic>

二:錯誤代碼

//全局變量int g_num = 0;void fun(){  for (int i = 0; i < 10000000; i++)  {    g_num++;  }  return ;}int main(){  //創建線程1  thread t1(fun);  //創建線程2  thread t2(fun);  t1.join();  t2.join();  cout << g_num << endl;  getchar();  return 1;}

應該輸出結果20000000,實際每次結果都不一樣,總是小于該值,正是由于多線程操作同一變量而沒有保證原子性導致的。

三:加鎖代碼

//全局變量int g_num = 0;mutex m_mutex;void fun(){  for (int i = 0; i < 10000000; i++)  {    m_mutex.lock();    g_num++;    m_mutex.unlock();  }  return ;}int main(){  //獲取當前毫秒時間戳  typedef chrono::time_point<chrono::system_clock, chrono::milliseconds> microClock_type;  microClock_type tp1 = chrono::time_point_cast<chrono::milliseconds>(chrono::system_clock::now());  long long time1 = tp1.time_since_epoch().count();  //創建線程  thread t1(fun);  thread t2(fun);  t1.join();  t2.join();  cout << "總數:" << g_num << endl;  //獲取當前毫秒時間戳  microClock_type tp2 = chrono::time_point_cast<chrono::milliseconds>(chrono::system_clock::now());  long long time2 = tp2.time_since_epoch().count();  cout << "耗時:" << time2 - time1 << "ms" << endl;  getchar();  return 1;}

執行結果:多次測試輸出均為20000000,耗時在3.8s左右

C++11,并發編程,原子操作,atomic,代碼

四:atomic原子操作代碼

//全局變量atomic<int> g_num = 0;void fun(){  for (int i = 0; i < 10000000; i++)  {    g_num++;  }  return ;}int main(){  //獲取當前毫秒時間戳  typedef chrono::time_point<chrono::system_clock, chrono::milliseconds> microClock_type;  microClock_type tp1 = chrono::time_point_cast<chrono::milliseconds>(chrono::system_clock::now());  long long time1 = tp1.time_since_epoch().count();  //創建線程  thread t1(fun);  thread t2(fun);  t1.join();  t2.join();  cout << "總數:" << g_num << endl;  //獲取當前毫秒時間戳  microClock_type tp2 = chrono::time_point_cast<chrono::milliseconds>(chrono::system_clock::now());  long long time2 = tp2.time_since_epoch().count();  cout << "耗時:" << time2 - time1 << "ms" << endl;  getchar();  return 1;}

執行結果:多次測試輸出均為20000000,耗時在1.3s左右

C++11,并發編程,原子操作,atomic,代碼

五:小結

c++11的原子類atomic相比使用加鎖機制性能有2~3倍提升,對于共享變量能用原子類型的就不要再用加鎖機制了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 云龙县| 福州市| 沿河| 西盟| 兴隆县| 鄯善县| 珠海市| 乌兰察布市| 巍山| 五寨县| 治县。| 崇州市| 鄄城县| 芜湖县| 蚌埠市| 温泉县| 钟山县| 灵璧县| 子洲县| 临沭县| 阿拉善盟| 太保市| 灌云县| 双牌县| 横山县| 乐至县| 大新县| 鄂州市| 米林县| 科尔| 黄大仙区| 盐山县| 博白县| 龙州县| 辛集市| 新兴县| 西青区| 大同县| 蒙自县| 焉耆| 班玛县|