centos里 C++项目 time() 和 gettimeofday() 返回不同的秒数

项目里有个地方获取时间戳需要比较精确,用了 gettimeofday()获取的
很多地方也引用了这里获取时间戳


	    struct timeval tv;
	    gettimeofday( &tv, NULL );
	    m_usec_time = (utime_t) tv.tv_sec * 1000 * 1000 + tv.tv_usec;
	    m_time = (time_t) tv.tv_sec;

而linux 下一般获取时间戳用time(NULL) 获取的,
实际项目发现 就算 time()后面调用  获取的时间 还是有概率 比gettimeofday获取到的时间晚一秒


这边做定时器时判定是用的 gettimeofday ,但逻辑里设置时间用的是time(NULL) 结果造成定时器出问题了。




查了一下
网上有人也遇到了这个问题,所以一个项目里时间戳接口要统一用一个,不要混用了
关于C#:time()和gettimeofday()返回不同的秒数 | 码农家园
(原文地址:
c - time() and gettimeofday() return different seconds - Stack Overflow

system_clock::now()和time()时间函数混用带来的踩坑经历_AlbertS的博客-CSDN博客

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值