1. 程式人生 > >C++ 11 多執行緒條件變數

C++ 11 多執行緒條件變數

條件變數顧名思義 , 使用條件觸發改變的變數。當某個執行緒當前執行的操作需要其他的另外一個執行緒的操作完成之後 , 當前執行緒才具備該操作 , 那麼當前執行緒就需要等待執行另外操作的執行緒執行完成以後,再執行當前的操作。在此環境下 , 條件變數就是排上用途了。

直接上程式碼,看操作:

#include<iostream>
#include<thread>
#include<mutex>
#include<condition_variable>
usingnamespacestd;
std::mutexmtx;
std::condition_variablecv;
inttmpVar=0;
voidexchage_variable()
{
std::lock_guard<std::mutex>tmp_lock(mtx);//建立自動互斥
tmpVar=1;//共享資源寫入資料
cv.notify_one();//共享資源寫入資料後通知喚醒執行緒
}
voidprint_variable()
{
std::unique_lock<std::mutex>lk(mtx);//建立自動互斥
cv.wait(lk);//阻塞當前執行緒等待執行緒被喚醒
cout<<tmpVar<<endl;//執行緒被喚醒後輸出共享資源中的資料
}
intmain()
{
std::thread
t2(print_variable);//建立執行緒t1並啟動該執行緒
std::threadt1(exchage_variable);//建立執行緒t2並啟動該執行緒
t1.join();
t2.join();
}
以上是最基本的條件變數操作。

相關推薦

C++ 11 執行條件變數

條件變數顧名思義 , 使用條件觸發改變的變數。當某個執行緒當前執行的操作需要其他的另外一個執行緒的操作完成之後 , 當前執行緒才具備該操作 , 那麼當前執行緒就需要等待執行另外操作的執行緒執行完成以後,再執行當前的操作。在此環境下 , 條件變數就是排上用途了。直接上程式碼,看

C++11執行---互斥量、鎖、條件變數的總結

關於互斥量std::mutex的總結 互斥量用於組成程式碼的臨界區。C++的多執行緒模型是基於記憶體的,或者說是基於程式碼片段的,這和我們作業系統學習的臨界區概念基本一致,但是與Golang不同,Golang是基於訊息模型的。 一個std::mutex的lock()和unlock

C++11執行程式設計 第七章: 條件變數及其使用方法

C++11 Multithreading – Part 7: Condition Variables Explained Varun June 2, 2015 C++11 Multithreading – Part 7: Condition Variables Explain

c++11執行 生產者-消費者模型/條件變數condition_variable

1.生產者消費者模型: 在工作中,大家可能會碰到這樣一種情況:某個模組負責產生資料,這些資料由另一個模組來負責處理(此處的模組是廣義的,可以是類、函式、執行緒、程序等)。產生資料的 模組,就形象地稱為生產者;而處理資料的模組,就稱為消費者。在生產者與消費者之間在加個緩衝區

C++11執行程式設計 第五章: 使用鎖來解決竟態條件

C++11 Multithreading – Part 5: Using mutex to fix Race Conditions Varun February 22, 2015 C++11 Multithreading – Part 5: Using mutex to fi

C++11執行程式設計 第四章: 共享資料和競態條件

C++11 Multithreading – Part 4: Data Sharing and Race Conditions Varun February 21, 2015C++11 Multithreading – Part 4: Data Sharing and Race Con

c++11執行程式設計(四):資料共享和競爭條件

在多執行緒環境中,執行緒間的資料共享很簡單,但是在程式中這種簡單的資料共享可能會引起問題,其中一種便是競爭條件。什麼是競爭條件? 競賽條件是發生在多執行緒應用程式中的一種bug 當兩個或多個執行緒並行執行一組操作,訪問相同的記憶體位置,此時,它們中的一個或多個執行緒會修改記

[轉]c++11 執行 future/promise

[轉自 https://blog.csdn.net/jiange_zh/article/details/51602938] 1. < future >標頭檔案簡介 Classes std::future std::future_error std::packaged_task std::pro

執行-條件變數

條件變數是一個能夠阻止呼叫執行緒直到通知恢復的物件。 它使用unique_lock(通過互斥鎖)在呼叫其中一個等待函式時鎖定執行緒。執行緒保持阻塞狀態,直到被另一個呼叫相同condition_variable物件上的通知函式的執行緒喚醒。 condition_variable型別的物件總

c++11執行 thread

 1.thread建構函式 default (1) thread() noexcept; initialization (2) template <class Fn, class... Args> explicit

C++11 執行執行共享資料

共享資料的問題 這些在作業系統中都有詳細的介紹,可以回顧作業系統課程。。很典型的就是資料競爭問題。 互斥量保護資料 最原始的方式:使用std::mutex建立互斥量,使用成員lock()加鎖,使用成員unlock()解鎖。但是這種方式需要我們在每個函數出口都呼叫一次unloc

c++11執行執行

最近需要開發一個高效能運算庫,涉及到c++多執行緒的應用,上次做類似的事情已經是4年多以前了,印象中還頗有些麻煩。悔當初做了就算了,也沒想著留點記錄什麼的。這次又研究了一番,發現用上c++11特性之後,現在已經比較簡單了,在此記錄一下。   最簡單的多執行緒情況,不涉及公共變數,各個執行緒之間獨

C++11執行(1)

        C++11中添加了duox多執行緒類,編寫C++程式可以直接使用C++11中的多執行緒庫,不必依賴於平臺多執行緒,這樣可以方便寫出誇平臺的多執行緒程式。多執行緒可以最大化利用計算機資源,提高程式碼的執行效率。         C++11中thread類提供兩

C++ 11 執行下std::unique_lock與std::lock_guard的區別和用法

這裡主要介紹std::unique_lock與std::lock_guard的區別用法 先說簡單的 一、std::lock_guard的用法 std::lock_guard其實就是簡單的RAII封裝,在建構函式中進行加鎖,解構函式中進行解鎖,這樣可以保證函式退出時,鎖一定被釋放。 簡單來說,就是防止開

C++11執行------std::async

std::async可以認為是封裝了一個std::promise,該函式返回一個std::future,用於獲取其他執行緒的資料。 一般有兩種模式: std::lanch::async:最常用的非同步模式,每次都要執行一遍 std::lanch::defer:只在第

C++11執行的原子操作

原子操作是同時只能有一個執行緒執行一個操作,不用使用互斥量即可實現,但是速度慢,而且一般只支援原生的型別,不夠靈活。更多的用處是作為訊號量進行使用。 示例程式碼,以int為例子: #include <atomic> #include <thread> #i

C++ 11 執行--執行管理

說到多執行緒程式設計,那麼就不得不提並行和併發,多執行緒是實現併發(並行)的一種手段。並行是指兩個或多個獨立的操作同時進行。注意這裡是同時進行,區別於併發,在一個時間段內執行多個操作。在單核時代,多個執行緒是併發的,在一個時間段內輪流執行;在多核時代,多個執行緒可以實現真正的並行,在多核上真正獨立的並行執行。

C++11執行程式設計 緒論及總結

C++11多執行緒程式設計 這一系列文章是從 https://thispointer.com/c11-multithreading-tutorial-series/ 轉過來的, 本來想翻譯一下, 但看了些內容, 用詞都不難, 讀英文沒有太大難度, 翻譯過來反而怕用詞不準畫蛇添

C++11執行程式設計 第十章: 使用packaged_task優雅的讓同步函式非同步執行

C++11 Multithreading – Part 10: packaged_task<> Example and Tutorial Varun July 2, 2017 C++11 Multithreading – Part 10: packaged_tas

C++11執行程式設計 第九章: std::async 更更優雅的寫執行

C++11 Multithreading – Part 9: std::async Tutorial & Example Varun May 5, 2017 C++11 Multithreading – Part 9: std::async Tutorial &