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::this_thread::yield
std::this_thread::yield
| å®ä¹äºå¤´æä»¶ <thread>
|
||
| void yield() noexcept; |
(C++11 èµ·) | |
æä¾æç¤ºç»å®ç°ï¼ä»¥éè°åº¦çº¿ç¨çæ§è¡ï¼å è®¸å ¶ä»çº¿ç¨è¿è¡ã
åæ°
ï¼æ ï¼
è¿åå¼
ï¼æ ï¼
注æ
æ¤å½æ°çåç¡®æ§ä¸ºä¾èµäºå®ç°ï¼ç¹å«æ¯ä½¿ç¨ä¸ç OS è°åº¦å¨æºå¶åç³»ç»ç¶æãä¾å¦ï¼å
è¿å
åºå®æ¶è°åº¦å¨ï¼ Linux ç SCHED_FIFO ï¼å°æ¬æå½å线ç¨å¹¶å°å®æ¾å°åå¤è¿è¡çåä¼å
级线ç¨çéåå°¾ï¼èè¥æ å
¶ä»çº¿ç¨å¨åä¼å
级ï¼å yield æ ææï¼ã
示ä¾
è¿è¡æ¤ä»£ç
#include <iostream> #include <chrono> #include <thread>  // å»ºè®®å ¶ä»çº¿ç¨è¿è¡ä¸å°æ®µæ¶é´çâå¿ç¡ç â void little_sleep(std::chrono::microseconds us) { auto start = std::chrono::high_resolution_clock::now(); auto end = start + us; do { std::this_thread::yield(); } while (std::chrono::high_resolution_clock::now() < end); }  int main() { auto start = std::chrono::high_resolution_clock::now();  little_sleep(std::chrono::microseconds(100));  auto elapsed = std::chrono::high_resolution_clock::now() - start; std::cout << "waited for " << std::chrono::duration_cast<std::chrono::microseconds>(elapsed).count() << " microseconds\n"; }
å¯è½çè¾åºï¼
waited for 128 microseconds