欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c++11中關(guān)于std::thread的join的詳解

 更新時(shí)間:2019年03月22日 09:09:47   作者:那一抹風(fēng)  
這篇文章主要介紹了c++11中關(guān)于std::thread的join詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

std::thread是c++11新引入的線程標(biāo)準(zhǔn)庫,通過其可以方便的編寫與平臺(tái)無關(guān)的多線程程序,雖然對(duì)比針對(duì)平臺(tái)來定制化多線程庫會(huì)使性能達(dá)到最大,但是會(huì)喪失了可移植性,這樣對(duì)比其他的高級(jí)語言,可謂是一個(gè)不足。終于在c++11承認(rèn)多線程的標(biāo)準(zhǔn),可謂可喜可賀?。?!

在使用std::thread的時(shí)候,對(duì)創(chuàng)建的線程有兩種操作:等待/分離,也就是join/detach操作。join()操作是在std::thread t(func)后“某個(gè)”合適的地方調(diào)用,其作用是回收對(duì)應(yīng)創(chuàng)建的線程的資源,避免造成資源的泄露。detach()操作是在std::thread t(func)后馬上調(diào)用,用于把被創(chuàng)建的線程與做創(chuàng)建動(dòng)作的線程分離,分離的線程變?yōu)楹笈_(tái)線程,其后,創(chuàng)建的線程的“死活”就與其做創(chuàng)建動(dòng)作的線程無關(guān),它的資源會(huì)被init進(jìn)程回收。

在這里主要對(duì)join做深入的理解。

由于join是等待被創(chuàng)建線程的結(jié)束,并回收它的資源。因此,join的調(diào)用位置就比較關(guān)鍵。比如,以下的調(diào)用位置都是錯(cuò)誤的。

void test()
{
}

bool do_other_things()
{
}

int main()
{
  std::thread t(test);
  int ret = do_other_things();
  if(ret == ERROR) {
    return -1;
  }

  t.join();
  return 0;
}

很明顯,如果do_other_things()函數(shù)調(diào)用返ERROR, 那么就會(huì)直接退出main函數(shù),此時(shí)join就不會(huì)被調(diào)用,所以線程t的資源沒有被回收,造成了資源泄露。

例子二:

void test()
{
}

bool do_other_things()
{
}

int main()
{
  std::thread t(test);

  try {
    do_other_things();
  }
  catch(...) {
    throw;
  }
  t.join();
  return 0;
}

這個(gè)例子和例子一差不多,如果調(diào)用do_other_things()函數(shù)拋出異常,那么就會(huì)直接終止程序,join也不會(huì)被調(diào)用,造成了資源沒被回收。

那么直接在異常捕捉catch代碼塊里調(diào)用join就ok啦。

例子三:

void test()
{
}

bool do_other_things()
{
}

int main()
{
  std::thread t(test);

  try {
    do_other_things();
  }
  catch(...) {
    t.join();
    throw;
  }
  t.join();
  return 0;
}

是不是很多人這樣操作?這樣做不是萬無一失的, try/catch塊只能夠捕捉輕量級(jí)的異常錯(cuò)誤,在這里如果在調(diào)用do_other_things()時(shí)發(fā)生嚴(yán)重的異常錯(cuò)誤,那么catch不會(huì)被觸發(fā)捕捉異常,同時(shí)造成程序直接從函數(shù)調(diào)用?;厮莘祷?,也不會(huì)調(diào)用到join,也會(huì)造成線程資源沒被回收,資源泄露。

所以在這里有一個(gè)方法是使用創(chuàng)建局部對(duì)象,利用函數(shù)調(diào)用棧的特性,確保對(duì)象被銷毀時(shí)觸發(fā)析構(gòu)函數(shù)的方法來確保在主線程結(jié)束前調(diào)用join(),等待回收創(chuàng)建的線程的資源。

class mythread {
private:
  std::thread &m_t;

public:
  explicit mythread(std::thread &t):m_t(t){}
  ~mythread() {
    if(t.joinable()) {
      t.join()
    }
  }

  mythread(mythread const&) = delete;
  mythread& operate=(mythread const&) = delete;
}

void test()
{
}

bool do_other_things()
{
}

int main()
{
  std::thread t(test);
  mythread q(t);

  if(do_other_things()) {
    return -1;
  }

  return 0;
}

在上面的例子中,無論在調(diào)用do_other_things()是發(fā)生錯(cuò)誤,造成return main函數(shù),還是產(chǎn)生異常,由于函數(shù)調(diào)用棧的關(guān)系,總會(huì)回溯的調(diào)用局部對(duì)象q的析構(gòu)函數(shù),同時(shí)在q的析構(gòu)函數(shù)里面先判斷j.joinable()是因?yàn)?code>join操作對(duì)于同一個(gè)線程只能調(diào)用一次,不然會(huì)出現(xiàn)錯(cuò)誤的。這樣,就可以確保線程一定會(huì)在主函數(shù)結(jié)束前被等待回收了。

以上所述是小編給大家介紹的c++11中關(guān)于std::thread的join詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • VS中PCL庫附加依賴項(xiàng)配置過程解析

    VS中PCL庫附加依賴項(xiàng)配置過程解析

    這篇文章主要介紹了VS中PCL庫附加依賴項(xiàng)配置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • C語言中二叉樹的后序遍歷詳解

    C語言中二叉樹的后序遍歷詳解

    大家好,本篇文章主要講的是C語言中二叉樹的后序遍歷詳解,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • C語言異常處理機(jī)制案例講解

    C語言異常處理機(jī)制案例講解

    這篇文章主要介紹了C語言異常處理機(jī)制案例講解,本文講解了異常處理機(jī)制所用的函數(shù)和具體的代碼實(shí)現(xiàn)等,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • c語言中abs()和fabs()的區(qū)別點(diǎn)整理

    c語言中abs()和fabs()的區(qū)別點(diǎn)整理

    在本篇文章里小編給大家分享的是關(guān)于c語言abs()和fabs()的區(qū)別,有需要的朋友們可以參考學(xué)習(xí)下。
    2020-02-02
  • 詳解DAG上的DP

    詳解DAG上的DP

    DAG:有向無環(huán)圖。DAG是學(xué)習(xí)動(dòng)態(tài)規(guī)劃的基礎(chǔ),很多問題都可以直接轉(zhuǎn)化為DAG上的最長路、最短路或路徑計(jì)數(shù)問題。本文將詳細(xì)介紹DAG上的DP。
    2021-05-05
  • C++ 仿函數(shù)使用講解

    C++ 仿函數(shù)使用講解

    這篇文章主要介紹了C++ 仿函數(shù)使用講解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • C++超詳細(xì)講解智能指針

    C++超詳細(xì)講解智能指針

    為了解決內(nèi)存泄漏的問題,C++中提出了智能指針。內(nèi)存泄漏的產(chǎn)生原因有很多,即使我們正確的使用malloc和free關(guān)鍵字也有可能產(chǎn)生內(nèi)存泄漏,如在malloc和free之間如果存在拋異常,那也會(huì)產(chǎn)生內(nèi)存泄漏。這種問題被稱為異常安全
    2022-06-06
  • 獲取本地網(wǎng)卡適配器信息具體代碼

    獲取本地網(wǎng)卡適配器信息具體代碼

    這篇文章主要介紹了獲取本地網(wǎng)卡適配器信息具體代碼,有需要的朋友可以參考一下
    2013-12-12
  • 詳解C語言中數(shù)據(jù)的存儲(chǔ)

    詳解C語言中數(shù)據(jù)的存儲(chǔ)

    這篇文章主要為大家介紹了C語言中數(shù)據(jù)的存儲(chǔ),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • 解決C++全局變量只能初始化不能賦值的問題

    解決C++全局變量只能初始化不能賦值的問題

    今天小編就為大家分享一篇解決C++全局變量只能初始化不能賦值的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07

最新評(píng)論