C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- std::thread
- std::stop_token
- std::stop_source
- std::stop_callback
- std::this_thread::get_id
- std::shared_timed_mutex
- std::shared_lock
- std::lock_guard
- std::hardware_destructive_interference_size, std::hardware_constructive_interference_size
- std::counting_semaphore, std::binary_semaphore
- std::jthread
- cpp/thread/barrier
- std::future
- std::this_thread::yield
- std::this_thread::sleep_for
- std::this_thread::sleep_until
- std::mutex
- std::recursive_mutex
- std::shared_mutex
- std::timed_mutex
- std::recursive_timed_mutex
- std::scoped_lock
- std::unique_lock
- std::defer_lock_t, std::try_to_lock_t, std::adopt_lock_t
- std::lock
- std::try_lock
- std::defer_lock, std::try_to_lock, std::adopt_lock
- std::once_flag
- std::call_once
- std::condition_variable
- std::condition_variable_any
- std::notify_all_at_thread_exit
- std::cv_status
- std::latch
- std::promise
- std::shared_future
- std::packaged_task
- std::async
- std::launch
- std::future_status
- std::future_error
- std::future_category
- std::future_errc
- 注é
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >çº¿ç¨æ¯æåº > std::condition_variable
std::condition_variable
| å®ä¹äºå¤´æä»¶ <condition_variable>
|
||
| class condition_variable; |
(C++11 èµ·) | |
condition_variable ç±»æ¯åæ¥åè¯ï¼è½ç¨äºé»å¡ä¸ä¸ªçº¿ç¨ï¼æåæ¶é»å¡å¤ä¸ªçº¿ç¨ï¼ç´è³å¦ä¸çº¿ç¨ä¿®æ¹å
±äº«åéï¼æ¡ä»¶ï¼å¹¶éç¥ condition_variable ã
ææä¿®æ¹åéç线ç¨å¿ é¡»
- è·å¾
std::mutexï¼å ¸åå°éè¿ std::lock_guard ï¼ - å¨ä¿æéæ¶è¿è¡ä¿®æ¹
- å¨
std::condition_variable䏿§è¡ notify_one æ notify_all ï¼ä¸éè¦ä¸ºéç¥ä¿æéï¼
å³ä½¿å ±äº«å鿝ååçï¼ä¹å¿ é¡»å¨äºæ¥ä¸ä¿®æ¹å®ï¼ä»¥æ£ç¡®å°åå¸ä¿®æ¹å°çå¾ ç线ç¨ã
任使æå¨ std::condition_variable ä¸çå¾
ç线ç¨å¿
é¡»
- è·å¾ std::unique_lock<std::mutex> ï¼å¨ä¸ç¨äºä¿æ¤å ±äº«åéè ç¸åçäºæ¥ä¸
- æ§è¡ wait ã wait_for æ wait_until ï¼çå¾ æä½èªå¨éæ¾äºæ¥ï¼å¹¶æ¬æçº¿ç¨çæ§è¡ã
- condition_variable 被éç¥æ¶ï¼æ¶éæ¶å¤±æèåå¤éåçï¼çº¿ç¨è¢«å¤éï¼ä¸èªå¨éè·å¾äºæ¥ãä¹å线ç¨åºæ£æ¥æ¡ä»¶ï¼è¥å¤éæ¯èåçï¼åç»§ç»çå¾ ã
std::condition_variable åªå¯ä¸ std::unique_lock<std::mutex> ä¸å使ç¨ï¼æ¤éå¶å¨ä¸äºå¹³å°ä¸å
许æå¤§æçã std::condition_variable_any æä¾å¯ä¸ä»»ä½åºæ¬å¯éå® (BasicLockable) 对象ï¼ä¾å¦ std::shared_lock ä¸å使ç¨çæ¡ä»¶åéã
condition_variable 容许 wait ã wait_for ã wait_until ã notify_one å notify_all æå彿°çåæ¶è°ç¨ã
ç±» std::condition_variable æ¯æ åå¸å±ç±»å (StandardLayoutType) ãå®ä¸å¯å¤å¶æé (CopyConstructible) ãå¯ç§»å¨æé (MoveConstructible) ãå¯å¤å¶èµå¼ (CopyAssignable) æå¯ç§»å¨èµå¼ (MoveAssignable) ã
æåç±»å
| Â | |
| æåç±»å | å®ä¹ |
native_handle_type
|
å®ç°å®ä¹ |
æå彿°
| æé 对象 (å ¬å¼æå彿°) | |
| ææå¯¹è±¡ (å ¬å¼æå彿°) | |
| operator= [被å é¤] |
ä¸å¯å¤å¶èµå¼ (å ¬å¼æå彿°) |
éç¥ | |
| éç¥ä¸ä¸ªçå¾
ççº¿ç¨ (å ¬å¼æå彿°) | |
| éç¥ææçå¾
ççº¿ç¨ (å ¬å¼æå彿°) | |
çå¾ | |
| é»å¡å½å线ç¨ï¼ç´å°æ¡ä»¶åé被å¤é (å ¬å¼æå彿°) | |
| é»å¡å½å线ç¨ï¼ç´å°æ¡ä»¶åé被å¤éï¼æå°æå®æ¶éæ¶é¿å (å ¬å¼æå彿°) | |
| é»å¡å½å线ç¨ï¼ç´å°æ¡ä»¶åé被å¤éï¼æç´å°æµè¾¾æå®æ¶é´ç¹ (å ¬å¼æå彿°) | |
åç奿 | |
| è¿ååç奿 (å ¬å¼æå彿°) | |
示ä¾
ä¸ std::mutex ç»åä½¿ç¨ condition_variable ï¼ä»¥ä¿è¿çº¿ç¨é´äº¤æµã
#include <iostream> #include <string> #include <thread> #include <mutex> #include <condition_variable>  std::mutex m; std::condition_variable cv; std::string data; bool ready = false; bool processed = false;  void worker_thread() { // çå¾ ç´è³ main() åéæ°æ® std::unique_lock<std::mutex> lk(m); cv.wait(lk, []{return ready;});  // çå¾ åï¼æä»¬å æéã std::cout << "Worker thread is processing data\n"; data += " after processing";  // åéæ°æ®å main() processed = true; std::cout << "Worker thread signals data processing completed\n";  // éç¥å宿æå¨è§£éï¼ä»¥é¿å çå¾ çº¿ç¨æè¢«å¤éå°±é»å¡ï¼ç»èè§ notify_one ï¼ lk.unlock(); cv.notify_one(); }  int main() { std::thread worker(worker_thread);  data = "Example data"; // åéæ°æ®å° worker çº¿ç¨ { std::lock_guard<std::mutex> lk(m); ready = true; std::cout << "main() signals data ready for processing\n"; } cv.notify_one();  // çå worker { std::unique_lock<std::mutex> lk(m); cv.wait(lk, []{return processed;}); } std::cout << "Back in main(), data = " << data << '\n';  worker.join(); }
è¾åºï¼
main() signals data ready for processing Worker thread is processing data Worker thread signals data processing completed Back in main(), data = Example data after processing