Linux 获取毫秒级时间戳
在Linux中获取ms级别的时间戳,需要结合gettimeofday()以及localtime()函数。如下所示:
#include <time.h>
#include <sys/time.h>
/* 日志时间戳,精确到毫秒 */
char* get_stime(void)
{
static char timestr[200] ={0};
struct tm * pTempTm;
struct timeval time;
gettimeofday(&time,NULL);
pTempTm = localtime(&time.tv_sec);
if( NULL != pTempTm )
{
snprintf(timestr,199,"%04d-%02d-%02d %02d:%02d:%02d.%03ld",
pTempTm->tm_year+1900,
pTempTm->tm_mon+1,
pTempTm->tm_mday,
pTempTm->tm_hour,
pTempTm->tm_min,
pTempTm->tm_sec,
time.tv_usec/1000);
}
return timestr;
}
首先通过gettimeofday()获取当前时间的秒级时刻以及微秒级时刻,注意这里是从标准UTC时间开始时经过的时间计数,而后通过localtime()将秒数转成本地时间,从而得到毫秒级时刻。
这里比较奇怪的是,在之前未通过localtime()将秒数转为当地时间时,直接对秒数进行%60计算,最后得到的秒数和实际时间却对不上,网上有人说需要进行时区的转换,即UTC+8,将获得时间加上8小时的偏移,但是计算结果还是不匹配,后续有时间研究研究。