使用C语言进行计时,在用户空间中可以使用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的定义为:
struct timeval
{
long tv_sec; //秒
long tv_usec;//微妙
}
struct timezone
{
int tz_minuteswest;//和格林威治时间差了多少分钟
int tz_dsttime; //日光节约时间的状态
}
可以看出,使用这种方式计时,精度可达微秒,也就是10-6秒。进行计时的时候,我们需要前后调用两次gettimeofday,然后计算中间的差值:
gettimeofday( &start, NULL );
foo();
gettimeofday( &end, NULL );
timeuse = 1000000 * ( end.tv_sec - start.tv_sec ) + end.tv_usec - start.tv_usec;
timeuse /= 1000000;
例程:
#include <sys/time.h>
#include <stdio.h>
int main()
{
struct timeval tv;
struct timezone tz;
gettimeofday(&tv,&tz);
printf("tv.tv_sec:%d\n",tv.tv_sec);
printf("tv.tv_usec:%d\n",tv.tv_usec);
printf("tz.tz_minuteswest:%d\n",tz.tz_minuteswest);
printf("tv.tz_dsttime:%d\n",tz.tz_dsttime);
return 0;
}
结果:
tv.tv_sec:1252081843
tv.tv_usec:119409
tz.tz_minuteswest:-480
tv.tz_dsttime:0