现在的位置: 首页 > 综合 > 正文

gettimeofday的用法详解

2013年10月04日 ⁄ 综合 ⁄ 共 504字 ⁄ 字号 评论关闭

在测试程序时,我们往往需要了解程序执行所需的时间,在C语言可以使用函数gettimeofday 来得到时间,它的调用格式是:

#include <sys/time.h>
int gettimeofday(struct timeval *tv, struct timezone *tz);
int settimeofday(const struct timeval *tv , const struct timezone *tz);

其中结构timeval的定义为:
strut timeval {
long tv_sec; /* 秒数 */
long tv_usec; /* 微秒数 */
};

可以看出,使用这种方式计时,精度可达微秒。进行计时的时候,我们需要前后调用两次gettimeofday,然后计算中间的差值:
gettimeofday( &start, NULL );
foo();      //示例函数
gettimeofday( &end, NULL );
timeuse = 1000000 * ( end.tv_sec - start.tv_sec ) + end.tv_usec - start.tv_usec;
timeuse /= 1000000;

其中start,end 是结构体所定义的timeval型。

抱歉!评论已关闭.