欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C語言

當(dāng)前位置:主頁 > 軟件編程 > C語言 >

C++11并發(fā)編程關(guān)于原子操作atomic的代碼示例

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊: 次

一:概述

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

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

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()
{
  //創(chuàng)建線程1
  thread t1(fun);
  //創(chuàng)建線程2
  thread t2(fun);
  t1.join();
  t2.join();
  cout << g_num << endl;
  getchar();
  return 1;
}

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

三:加鎖代碼

//全局變量
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()
{
  //獲取當(dāng)前毫秒時間戳
  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();
  //創(chuàng)建線程
  thread t1(fun);
  thread t2(fun);
  t1.join();
  t2.join();
  cout << "總數(shù):" << g_num << endl;
  //獲取當(dāng)前毫秒時間戳
  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;
}

執(zhí)行結(jié)果:多次測試輸出均為20000000,耗時在3.8s左右

四:atomic原子操作代碼

//全局變量
atomic<int> g_num = 0;
void fun()
{
  for (int i = 0; i < 10000000; i++)
  {
    g_num++;
  }
  return ;
}
int main()
{
  //獲取當(dāng)前毫秒時間戳
  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();
  //創(chuàng)建線程
  thread t1(fun);
  thread t2(fun);
  t1.join();
  t2.join();
  cout << "總數(shù):" << g_num << endl;
  //獲取當(dāng)前毫秒時間戳
  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;
}

執(zhí)行結(jié)果:多次測試輸出均為20000000,耗時在1.3s左右

五:小結(jié)

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對我們的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

上一篇:C++實現(xiàn)遞歸函數(shù)的方法

欄    目:C語言

下一篇:C++構(gòu)造和解析Json的使用示例

本文標(biāo)題:C++11并發(fā)編程關(guān)于原子操作atomic的代碼示例

本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/575.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有