【Linux编程】如何将gettimeofday获取的时间信息转换成可显示的字符串时间?

版权声明:本文为博主【北纬22.5度的攻城狮】原创文章,转载请务必注明出处! https://blog.csdn.net/szullc/article/details/84946251

大家在平时的项目中,一定经常面临打日志信息的问题,在打日志这个问题上,大家有时一定会非常关注【时间戳】这个信息点。

想必大家也很经常使用【gettimeofday】接口来获取当前的系统时间,但是很遗憾的是,它获取的时间信息是存储在一个叫strcut timeval的结构体中。那么如何将这个结构体的时间信息转换为可是显示的时间字符串呢?

比如显示 "2018-12-10 20:52:00"。本文就将给你答案,直接附上代码:

#include <stdio.h>
#include <stdlib.h>
#include <sys/time.h>
#include <time.h>

//由struct timeval结构体数据(由gettimeofday获取到的)转换成可显示的时间字符串
static char * get_local_time(char *time_str, int len, struct timeval *tv)
{
    struct tm* ptm;
    char time_string[40];
    long milliseconds;
    
    ptm = localtime (&(tv->tv_sec));

    /* 格式化日期和时间,精确到秒为单位。*/
    //strftime (time_string, sizeof(time_string), "%Y/%m/%d %H:%M:%S", ptm); //输出格式为: 2018/12/09 10:48:31.391
    //strftime (time_string, sizeof(time_string), "%Y|%m|%d %H-%M-%S", ptm); //输出格式为: 2018|12|09 10-52-28.302
    //strftime (time_string, sizeof(time_string), "%Y-%m-%d %H:%M:%S", ptm); //输出格式为: 2018-12-09 10:52:57.200
    strftime (time_string, sizeof(time_string), "%Y\\%m\\%d %H-%M-%S", ptm); //输出格式为: 2018\12\09 10-52-28.302

    /* 从微秒计算毫秒。*/
    milliseconds = tv->tv_usec / 1000;

    /* 以秒为单位打印格式化后的时间日期,小数点后为毫秒。*/
    snprintf (time_str, len, "%s.%03ld", time_string, milliseconds);

    return time_str;
}

int main(int argc, const char **argv)
{
    char local_time_str[128];
    char *p = NULL;
    struct timeval tv;

    gettimeofday(&tv, NULL);
    p = get_local_time(local_time_str, sizeof(local_time_str), &tv);
    printf("Get local time: \n%s\n", p);

    return 0;
}

编译代码,输入:

gcc -o time_string_format time_string_format.c

测试结果如下:

上文的示例代码中,给出了好几种打印时间戳格式的示例,笔者只演示了其他的一种,其他的几种,有待读者亲自去验证。验证的过程中,如果有发现什么问题,可随时与我联系。

版权申明:本文为博主原创文章,转载请注明出处!https://blog.csdn.net/szullc/article/details/84946251

原创作者:李路昌

电子邮箱:[email protected]

猜你喜欢

转载自blog.csdn.net/szullc/article/details/84946251