linux下c++的计时函数

方法一:
#include<time.h>
clock_t start = clock();
需要计时的代码段
clock_t end = clock();
运行时间t = end - start; (单位ms)

本方法有一定缺陷,在32bit机器上,运行时间较长达到(超过1小时),有可能出现计时错误。
clock()文档说明如下:
Note that the time can wrap around. On a 32-bit system where CLOCKS_PER_SEC equals 1000000 this function will return the same value approximately every 72 minutes.

因此,当出现计时为负数或者很小的数时,需要人为凭经验加上若干个72minutes。。。

方法二:
显然方法一有一定局限性,方法二解决了长时间计时的问题。
#include<time.h>
timeval start, end; 
gettimeofday(&start, null);
需要计时的代码段
gettimeofday(&end, null);
运行时间t = 1000*(end.tv_sec - start.tv_sec) + (end.tv_usec - start.tv_usec)/1000; (单位ms)

 

本文出自:http://2xvision.blog.163.com/blog/static/21803373200942763542621/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值