91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c++11中關于std::thread的join的詳解

發布時間:2020-09-24 09:15:06 來源:腳本之家 閱讀:390 作者:那一抹風 欄目:編程語言

std::thread是c++11新引入的線程標準庫,通過其可以方便的編寫與平臺無關的多線程程序,雖然對比針對平臺來定制化多線程庫會使性能達到最大,但是會喪失了可移植性,這樣對比其他的高級語言,可謂是一個不足。終于在c++11承認多線程的標準,可謂可喜可賀!!!

在使用std::thread的時候,對創建的線程有兩種操作:等待/分離,也就是join/detach操作。join()操作是在std::thread t(func)后“某個”合適的地方調用,其作用是回收對應創建的線程的資源,避免造成資源的泄露。detach()操作是在std::thread t(func)后馬上調用,用于把被創建的線程與做創建動作的線程分離,分離的線程變為后臺線程,其后,創建的線程的“死活”就與其做創建動作的線程無關,它的資源會被init進程回收。

在這里主要對join做深入的理解。

由于join是等待被創建線程的結束,并回收它的資源。因此,join的調用位置就比較關鍵。比如,以下的調用位置都是錯誤的。

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()函數調用返ERROR, 那么就會直接退出main函數,此時join就不會被調用,所以線程t的資源沒有被回收,造成了資源泄露。

例子二:

void test()
{
}

bool do_other_things()
{
}

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

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

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

那么直接在異常捕捉catch代碼塊里調用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塊只能夠捕捉輕量級的異常錯誤,在這里如果在調用do_other_things()時發生嚴重的異常錯誤,那么catch不會被觸發捕捉異常,同時造成程序直接從函數調用棧回溯返回,也不會調用到join,也會造成線程資源沒被回收,資源泄露。

所以在這里有一個方法是使用創建局部對象,利用函數調用棧的特性,確保對象被銷毀時觸發析構函數的方法來確保在主線程結束前調用join(),等待回收創建的線程的資源。

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;
}

在上面的例子中,無論在調用do_other_things()是發生錯誤,造成return main函數,還是產生異常,由于函數調用棧的關系,總會回溯的調用局部對象q的析構函數,同時在q的析構函數里面先判斷j.joinable()是因為join操作對于同一個線程只能調用一次,不然會出現錯誤的。這樣,就可以確保線程一定會在主函數結束前被等待回收了。

以上所述是小編給大家介紹的c++11中關于std::thread的join詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

荔浦县| 巍山| 渭南市| 嘉义县| 绵竹市| 察雅县| 兰溪市| 通榆县| 方正县| 和硕县| 宝兴县| 江阴市| 海原县| 伊金霍洛旗| 陆丰市| 墨玉县| 承德县| 平和县| 庆阳市| 阳泉市| 奉新县| 蚌埠市| 上林县| 廉江市| 邹城市| 池州市| 吉木乃县| 桂林市| 东莞市| 肥西县| 唐海县| 威远县| 卢湾区| 姚安县| 保康县| 嘉义市| 桦甸市| 灵武市| 奈曼旗| 沁阳市| 河池市|