最近在项目中使用到了gettimeofday这个函数来计算系统当前毫秒数,发现这里面有个问题需要特别注意一下。
1、首先来看一下函数原型:
int gettimeofday(struct timeval *tv, struct timezone *tz)
其中结构体struct timeval定义如下:
struct timeval {
time_t tv_sec; /* seconds */
suseconds_t tv_usec; /* microseconds */
};
其中time_t和suseconds_t都是long int类型。
2、在利用tv_sec和tv_usec计算毫秒数时,需要注意溢出的问题。
struct timeval tv;
long long msec = (long long)tv.tv_sec * 1000 + tv.tv_usec / 1000;
通过以上方式可以获得系统当前的毫秒数,这里需要注意的是,当系统为32位时msec变量需要定义为long long类型,因为对于32位系统来数,long的长度为32位,取值范围为-2,147,483,648~2,147,483,647,会溢出。