thrd_yield
From cppreference.com
| ヘッダ <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> // utility function: difference between timespecs in microseconds 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; } // busy wait while yielding 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 The thrd_yield function (p: 281)
- C11標準 (ISO/IEC 9899:2011)
- 7.26.5.8 The thrd_yield function (p: 385)
[編集] 関連項目
| (C11) |
呼び出しスレッドの実行を、与えられた期間だけ一時停止する (関数) |
| C++ドキュメント の yield
| |