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::shared_future
std::shared_future
| å®ä¹äºå¤´æä»¶ <future>
|
||
| template< class T > class shared_future; |
(1) | (C++11 èµ·) |
| template< class T > class shared_future<T&>; |
(2) | (C++11 èµ·) |
| template<> Â Â Â Â Â class shared_future<void>; |
(3) | (C++11 èµ·) |
ç±»æ¨¡æ¿ std::shared_future æä¾è®¿é®å¼æ¥æä½ç»æçæºå¶ï¼ç±»ä¼¼ std::future ï¼é¤äºå
许å¤ä¸ªçº¿ç¨çååä¸å
±äº«ç¶æãä¸åäºä»
å¯ç§»å¨ç std::future ï¼æ
åªæä¸ä¸ªå®ä¾è½æä»£ä»»ä½ç¹å®ç弿¥ç»æï¼ï¼std::shared_future å¯å¤å¶èä¸å¤ä¸ª shared_future å¯¹è±¡è½æä»£åä¸å
±äº«ç¶æã
è¥æ¯ä¸ªçº¿ç¨éè¿å
¶èªèº«ç shared_future å¯¹è±¡å¯æ¬è®¿é®ï¼åä»å¤ä¸ªçº¿ç¨è®¿é®åä¸å
±äº«ç¶ææ¯å®å
¨çã
æå彿°
| æé future 对象 (å ¬å¼æå彿°) | |
| 鿝future对象 (å ¬å¼æå彿°) | |
| èµå¼å
容 (å ¬å¼æå彿°) | |
è·åç»æ | |
| è¿åç»æ (å ¬å¼æå彿°) | |
ç¶æ | |
| æ£æ¥ future æ¯å¦æ¥æå
±äº«ç¶æ (å ¬å¼æå彿°) | |
| çå¾
ç»æåå¾å¯ç¨ (å ¬å¼æå彿°) | |
| çå¾
ç»æï¼å¦æå¨æå®çè¶
æ¶é´éåä»ç¶æ æ³å¾å°ç»æï¼åè¿åã (å ¬å¼æå彿°) | |
| çå¾
ç»æï¼å¦æå¨å·²ç»å°è¾¾æå®çæ¶é´ç¹æ¶ä»ç¶æ æ³å¾å°ç»æï¼åè¿åã (å ¬å¼æå彿°) | |
示ä¾
shared_future å¯ç¨äºåæ¶åå¤ä¸ªçº¿ç¨åä¿¡ï¼ç±»ä¼¼ std::condition_variable::notify_all()
è¿è¡æ¤ä»£ç
#include <iostream> #include <future> #include <chrono>  int main() { std::promise<void> ready_promise, t1_ready_promise, t2_ready_promise; std::shared_future<void> ready_future(ready_promise.get_future());  std::chrono::time_point<std::chrono::high_resolution_clock> start;  auto fun1 = [&, ready_future]() -> std::chrono::duration<double, std::milli> { t1_ready_promise.set_value(); ready_future.wait(); // çå¾ æ¥èª main() çä¿¡å· return std::chrono::high_resolution_clock::now() - start; };   auto fun2 = [&, ready_future]() -> std::chrono::duration<double, std::milli> { t2_ready_promise.set_value(); ready_future.wait(); // çå¾ æ¥èª main() çä¿¡å· return std::chrono::high_resolution_clock::now() - start; };  auto result1 = std::async(std::launch::async, fun1); auto result2 = std::async(std::launch::async, fun2);  // çå¾ çº¿ç¨å为就绪 t1_ready_promise.get_future().wait(); t2_ready_promise.get_future().wait();  // 线ç¨å·²å°±ç»ªï¼å¼å§æ¶é start = std::chrono::high_resolution_clock::now();  // å线ç¨å信使ä¹è¿è¡ ready_promise.set_value();  std::cout << "Thread 1 received the signal " << result1.get().count() << " ms after start\n" << "Thread 2 received the signal " << result2.get().count() << " ms after start\n"; }
å¯è½çè¾åºï¼
Thread 1 received the signal 0.072 ms after start Thread 2 received the signal 0.041 ms after start