Provided by: manpages-ja-dev_0.5.0.0.20221215+dfsg-1_all
名前
clock_nanosleep - 指定したクロックでの高精度な実行停止 (sleep)
書式
#include <time.h> int clock_nanosleep(clockid_t clockid, int flags, const struct timespec *request, struct timespec *remain); -lrt とリンクする (バージョン 2.17 より前の glibc のみ) glibc 向けの機能検査マクロの要件 (feature_test_macros(7) 参照): clock_nanosleep(): _POSIX_C_SOURCE >= 200112L
説明
clock_nanosleep() を使うと、 nanosleep(2) 同様、ナノ秒の精度で指定された期間だけ呼び出し たスレッドの実行を 停止することができる。 nanosleep(2) と違うのは、呼び出し側が停止期間を どのクロックに対して計測するのかを選択 できる点と、停止期間を絶対値でも相対値でも指定でき る点である。 このシステムコールに渡したり、このシステムコールが返したりする時間の値は timespec 構造体を 使って指定される。この構造体の定義は以下の通りである。 struct timespec { time_t tv_sec; /* seconds */ long tv_nsec; /* nanoseconds [0 .. 999999999] */ }; clockid 引数で、停止期間をどのクロックに対して計測するかを指定する。 この引数には以下の値 のいずれか一つを指定できる。 CLOCK_REALTIME システム全体で使われる実時間クロック。 このクロックは変更可能である。 CLOCK_TAI (Linux 3.10 以降) A system-wide clock derived from wall-clock time but ignoring leap seconds. CLOCK_MONOTONIC 過去のある時点からの時間を計測する、単調増加のクロック。 起点となる時点はシステム起 動後には変更されない。 このクロックは変更することができない。 CLOCK_BOOTIME (Linux 2.6.39 以降) Identical to CLOCK_MONOTONIC, except that it also includes any time that the system is suspended. CLOCK_PROCESS_CPUTIME_ID そのプロセスの全スレッドで消費される CPU 時間を計測するプロセス単位の クロック。こ のクロックは設定可能である。 これらのクロックの詳細は clock_getres(2) を参照。 また、 clock_getcpuclockid(3) と pthread_getcpuclockid(3) が返す CPU クロック ID は clockid に渡すこともできる。 flags が 0 の場合、 request に指定された値は clockid で指定されたクロックの現在の値からの 相対的な期間と解釈される。 flags が TIMER_ABSTIME の場合、 request は指定されたクロック clockid で計測される絶対時刻 と解釈される。 request が指定されたクロックの現在の値以下の場合、 clock_nanosleep() は、呼 び出したスレッドの停止を行わず、すぐに返る。 clock_nanosleep() は、少なくとも request で指定された時間が経過するまで、呼び出したスレッ ドの実行を停止する。 シグナルハンドラーが呼び出されたり、そのプロセスを終了させるような シ グナルが配送されたりした場合にも、スレッドの実行停止は終了する。 呼び出しがシグナルハンドラーによって割り込まれた場合、 clock_nanosleep() はエラー EINTR で失敗する。さらに、 remain が NULL でなく、かつ flags が TIMER_ABSTIME でない場合には、 remain に残りの停止時間が返される。 この値を使って clock_nanosleep() を再度呼び出すこと で、(相対的な期間の) 停止を完了することができる。
返り値
要求された期間の停止に成功すると、 clock_nanosleep() は 0 を返す。 シグナルハンドラーで割 り込まれたり、エラーが発生したりした場合、 「エラー」の節のリストにある正のエラー番号のい ずれか一つを返す。
エラー
EFAULT request や remain に無効なアドレスが指定された。 EINTR 停止がシグナルハンドラーにより割り込まれた。 signal(7) 参照。 EINVAL tv_nsec フィールドの値が 0 から 999999999 の範囲でないか、 tv_sec の値が負であっ た。 EINVAL clockid が無効であった (CLOCK_THREAD_CPUTIME_ID が clockid として有効な値ではな い)。 ENOTSUP The kernel does not support sleeping against this clockid.
バージョン
clock_nanosleep() システムコールは Linux 2.6 で初めて登場した。 glibc ではバージョン 2.1 以降でサポートされている。
準拠
POSIX.1-2001, POSIX.1-2008.
注意
request で指定された停止期間が、時間の計測に使用されるクロック (time(7) 参照) の精度の倍 数ちょうどでない場合、停止期間は一番近い次の倍数に 切り上げられる。さらに、停止が完了した 後に、CPU が呼び出したスレッドを もう一度実行できるようになるまでには、遅延が入る可能性が ある。 絶対値指定のタイマーを使うのは、 nanosleep(2) に書かれている類のタイマーのずれの問題を防 止するのに役立つ (この種の問題は、シグナルに割り込まれた際に相対指定の停止を 繰り返し再開 しようとするプログラムでは、かえって悪化する)。 これらの問題を回避して相対指定の停止を実行 するには、 希望するクロックで clock_gettime(2) を呼び出し、その返り値の時刻値に希望する期 間を加算してから、 TIMER_ABSTIME フラグを指定して clock_nanosleep() を呼び出す。 sigaction(2) で SA_RESTART フラグが指定されているかに関わらず、シグナルハンドラーにより割 り込まれた後に clock_nanosleep() が再開されることは決してない。 flags が TIMER_ABSTIME の場合、 remain 引数は使用されず、不要である (絶対値での停止で は、同じ request 引数を使って再度呼び出すことができる)。 POSIX.1 の規定では、 clock_nanosleep() はシグナルの処理方法やシグナルマスクに影響を与えな い、とされている。 POSIX.1 の規定では、 clock_settime(2) で CLOCK_REALTIME クロックの値を変更した後は、絶対 値指定の clock_nanosleep() で停止しているスレッドを起動させる時刻の判定は、 新しいクロッ ク値を使って行われる、とされている。 新しいクロック値において停止期間の終了時刻が過去に なってしまった場合には、 clock_nanosleep() はすぐに返ることになる。 POSIX.1 の規定では、 clock_settime(2) で CLOCK_REALTIME クロックの値を変更しても、相対値 指定の clock_nanosleep() で停止しているスレッドには影響を与えない、とされている。
関連項目
clock_getres(2), nanosleep(2), restart_syscall(2), timer_create(2), sleep(3), usleep(3), time(7)
この文書について
この man ページは Linux man-pages プロジェクトのリリース 5.10 の一部である。プロジェクトの 説明とバグ報告に関する情報は https://www.kernel.org/doc/man-pages/ に書かれている。