Linux 获取毫秒级时间戳

15 篇文章 1 订阅

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小时的偏移,但是计算结果还是不匹配,后续有时间研究研究。

  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值