pthread_cond_timedwait返回EINVAL

最近发现程序的business.wait(100); 使用起来造成cpu负载很高

代码如下:

    struct timespec delay;
    if ( !clock_gettime(CLOCK_REALTIME,&delay) )
    {
        delay.tv_sec += (int)(waitmillsseconds / 1000);
        delay.tv_nsec += (waitmillsseconds % 1000)*1000000;
    }
    int err = pthread_cond_timedwait(&cond, &lock, &delay); // err会一直返回EINVAL

后来打印发现出现错误时:

clock_gettime tv_sec=1409711645, tv_nsec=1087094042; // 这里面的tv_nsec的值超过了10的9次方  也就是超过了1秒
errno 22 is EINVAL

后来修改:

    delay.tv_sec += (int)(waitmillsseconds / 1000);
    delay.tv_nsec += (waitmillsseconds % 1000)*1000000;
    if (delay.tv_nsec > 1000000000) {
	delay.tv_sec += 1;
	delay.tv_nsec -= 1000000000;
    }
这样修改后就没有问题了

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值