c实现日志时间字符串,可精确到微秒获取

代码如下:

#include <stdarg.h>
#include <time.h>
#include <stdlib.h>
#include <stdio.h>

#define TIMEVAL_TO_STR_BUFFER_SIZE 37

int print_error(const char *format, ...)
{
  int r;
  va_list l;

  va_start(l, format);
  vfprintf(stderr, format, l);
  r = fprintf(stderr, "\n");
  fflush(stderr);
  va_end(l);

  return r;
}

void timeval_to_str(struct timeval *clock, char *const buffer)
{
  struct tm result;
  localtime_r(&clock->tv_sec, &result);
#if 0
  sprintf(buffer, "%04d/%02d/%02d %02d:%02d:%02d.%06d",
          result.tm_year + 1900,
          result.tm_mon + 1,
          result.tm_mday,
          result.tm_hour,
          result.tm_min,
          result.tm_sec,
          (int)(clock->tv_usec / 100000)
         );
#else
  sprintf(buffer, "%04d/%02d/%02d %02d:%02d:%02d",
          result.tm_year + 1900,
          result.tm_mon + 1,
          result.tm_mday,
          result.tm_hour,
          result.tm_min,
          result.tm_sec
         );

#endif
}


double timeval_to_double(struct timeval *tv)
{
  return ((double)(tv->tv_sec) + (double)(tv->tv_usec) * 0.000001);
}

void print_time_diff(void)
{
  char datetime_buf[TIMEVAL_TO_STR_BUFFER_SIZE];
  static double pre_time = 0.0;

  struct timeval tv;
  gettimeofday(&tv, NULL);
  timeval_to_str(&tv, datetime_buf);
  double current_time = timeval_to_double(&tv);

  if (pre_time) {
    double time_diff = current_time - pre_time;
    print_error("%s (diff %10.6lf)", datetime_buf, time_diff);
  } else {
    print_error("%s", datetime_buf);
  }
  pre_time = current_time;
}

int main(int argc, char *argv[])
{
    print_time_diff();
    return 0;
}

运行结果:2019/05/22 07:20:04

毫秒级别:2019/05/22 07:22:47.005

微妙级别:2019/05/22 07:21:46.000001

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值