命名空间
变体
操作

thrd_sleep

来自 cppreference.cn
< c‎ | thread
定义于头文件 <threads.h>
int thrd_sleep( const struct timespec* duration,
                struct timespec* remaining );
(自 C11 起)

至少阻塞当前线程的执行,直到由 duration 指向的基于 TIME_UTC 的时长经过。

如果收到一个未被忽略的 信号,睡眠可能会提前恢复。在这种情况下,如果 remaining 不是 NULL,则剩余时间时长存储到由 remaining 指向的对象中。

内容

[编辑] 参数

duration - 指向睡眠时长的指针
remaining - 指向用于存放中断后剩余时间的对象的指针。可以为 NULL,在这种情况下会被忽略

[编辑] 返回值

0 睡眠成功时返回 -1,如果发生信号则返回,如果发生错误则返回其他负值。

[编辑] 注解

durationremaining 可以指向同一对象,这简化了在信号后重新运行函数的操作。

实际睡眠时间可能比请求的时间长,因为它会被向上舍入到计时器粒度,并且由于调度和上下文切换开销。

此函数的 POSIX 等效函数是 nanosleep

[编辑] 示例

#include <threads.h>
#include <time.h>
#include <stdio.h>
 
int main(void)
{
    printf("Time: %s", ctime(&(time_t){time(NULL)}));
    thrd_sleep(&(struct timespec){.tv_sec=1}, NULL); // sleep 1 sec
    printf("Time: %s", ctime(&(time_t){time(NULL)}));
}

输出

Time: Mon Feb  2 16:18:41 2015
Time: Mon Feb  2 16:18:42 2015

[编辑] 参考

  • C17 标准 (ISO/IEC 9899:2018)
  • 7.26.5.7 thrd_sleep 函数 (p: 281)
  • C11 标准 (ISO/IEC 9899:2011)
  • 7.26.5.7 thrd_sleep 函数 (p: 385)

[编辑] 参见

让出当前时间片
(函数) [编辑]
C++ 文档 关于 sleep_for