名前空間
変種
操作

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)

[編集] 関連項目

呼び出しスレッドの実行を、与えられた期間だけ一時停止する
(関数) [編集]
English 日本語 中文(简体) 中文(繁體)