thrd_yield
From cppreference.net
|
ヘッダーで定義
<threads.h>
|
||
|
void
thrd_yield
(
void
)
;
|
(C11以降) | |
スレッドの実行を再スケジュールし、他のスレッドが実行できるようにする実装へのヒントを提供します。
目次 |
パラメータ
(なし)
戻り値
(なし)
注記
この関数の正確な動作は実装に依存します。特に、使用中のOSスケジューラの仕組みとシステムの状態によって異なります。例えば、FIFO(先入れ先出し)リアルタイムスケジューラ(Linuxの
SCHED_FIFO
など)は、現在のスレッドを中断し、実行準備が整っている同じ優先度のスレッドのキュー末尾に配置します。同じ優先度の他のスレッドが存在しない場合、
yield
は効果を持ちません。
この関数のPOSIXに相当するものは
sched_yield
です。
例
このコードを実行
#include <stdio.h> #include <time.h> #include <threads.h> // ユーティリティ関数: timespec間の差分をマイクロ秒で計算 double usdiff(struct timespec s, struct timespec e) { double sdiff = difftime(e.tv_sec, s.tv_sec); long nsdiff = e.tv_nsec - s.tv_nsec; if(nsdiff < 0) return 1000000*(sdiff-1) + (1000000000L+nsdiff)/1000.0; else return 1000000*(sdiff) + nsdiff/1000.0; } // ビジーウェイト(スレッド譲渡を伴う) void sleep_100us() { struct timespec start, end; timespec_get(&start, TIME_UTC); do { thrd_yield(); timespec_get(&end, TIME_UTC); } while(usdiff(start, end) < 100.0); } int main() { struct timespec start, end; timespec_get(&start, TIME_UTC); sleep_100us(); timespec_get(&end, TIME_UTC); printf("Waited for %.3f us\n", usdiff(start, end)); }
出力例:
Waited for 100.344 us
参考文献
- C17規格 (ISO/IEC 9899:2018):
-
- 7.26.5.8 thrd_yield関数 (p: 281)
- C11規格 (ISO/IEC 9899:2011):
-
- 7.26.5.8 thrd_yield関数 (p: 385)
関連項目
|
(C11)
|
呼び出し元スレッドの実行を指定された期間だけ停止する
(関数) |
|
C++ documentation
for
yield
|
|