std::this_thread::yield

出自cppreference.com
< cpp‎ | thread
 
 
並發支持庫
線程
(C++11)
(C++20)
this_thread 命名空間
(C++11)
yield
(C++11)
(C++11)
協作式取消
互斥
(C++11)
通用鎖管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
條件變數
(C++11)
信號量
閂與屏障
(C++20)
(C++20)
未來體
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
風險指針
原子類型
(C++11)
(C++20)
原子類型的初始化
(C++11)(C++20 棄用)
(C++11)(C++20 棄用)
內存定序
(C++11)(C++26 棄用)
原子操作的自由函數
原子標誌的自由函數
 
在標頭 <thread> 定義
void yield() noexcept;
(C++11 起)

向實現提供一個提示,重新調度線程的執行以允許其他線程運行。

目錄

[編輯] 參數

(無)

[編輯] 返回值

(無)

[編輯] 註解

此函數的確切行為依賴於實現,特別是取決於使用中的 OS 調度器機制和系統狀態。例如,先進先出實時調度器(Linux 的 SCHED_FIFO)會掛起當前線程並將它放到準備運行的同優先順序線程的隊列尾,而若無其他線程在同優先順序,則 yield 無效果。

[編輯] 示例

#include <chrono>
#include <iostream>
#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 << "等待 "
              << std::chrono::duration_cast<std::chrono::microseconds>(elapsed).count()
              << " 微秒\n";
}

可能的輸出:

等待 128 微秒

[編輯] 參閱

thrd_yield 的 C 文檔