在测试程序时,我们往往需要了解程序执行所需的时间,在C语言可以使用函数gettimeofday来得到时间,它的调用格式是:
#include int gettimeofday(struct timeval *tv,struct timezone *tz);int settimeofday(const struct timeval *tv , const structtimezone *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型。