Namespaces
Variants

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)

関連項目

呼び出し元スレッドの実行を指定された期間だけ停止する
(関数)