c++打印封装每次打印前面加上时间戳问题

 更新时间:2024年01月01日 10:49:17   作者:不是杠杠  
这篇文章主要介绍了c++打印封装每次打印前面加上时间戳问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

c++打印封装每次打印前面加上时间戳

封装之后我们打印不必每次都加上时间

#include <iostream>
#include <time.h>
#include <sys/time.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <string>
#include <mutex>
#include <pthread.h>
#include <thread> 
#include <unistd.h> 
std::mutex g_mtx;
void printfTime()
{
    char buf[32] = {0};
	struct timeval tv;
	struct tm      tm;
	size_t         len = 28;
	memset(&tv, 0, sizeof(tv));
	memset(&tm, 0, sizeof(tm));
	gettimeofday(&tv, NULL);
	localtime_r(&tv.tv_sec, &tm);
	strftime(buf, len, "%Y-%m-%d %H:%M:%S", &tm);
	len = strlen(buf);
	sprintf(buf + len, ".%-6.3d", (int)(tv.tv_usec/1000)); 
    printf("%s",buf);
}
void printXX()
{
    std::cout<<std::endl;
}
 
template <typename T,typename... types>
 
void printXX(const T& firstArg,const types&... arges)
{
    std::cout<<firstArg;
    printXX(arges...);
}
template <typename T,typename... types>
 
void mvPrintf(const T& firstArg,const types&... arges)
{
    std::lock_guard<std::mutex> lock(g_mtx);
    printfTime();
    printXX(firstArg,arges...);
}
 
int main()
{   
    int i = 0;
    std::string a="ddddd";
    mvPrintf("i = ", i, " a = ",a);
    i = 1000;
    mvPrintf("i = ", i, " a = ",a);
    mvPrintf("ssssssssssssssssssssssssssssssss ");
    return 0;
}

输出:

c++获取、打印当前时间:time、localtime

先来总结下

1、函数1为基本的获取time_t格式时间函数;

2、函数3、4为转换为tm格式时间函数;

3、函数2、5、6为输出可读格式时间函数。

4、其中函数2、5不符合使用习惯,因此不长使用,常用函数6定制化输出。

以下函数全部在#include <ctime>中。

1、time_t time(time_t *seconds):

函数描述:返回基于当前系统的自纪元起经过的时间,以秒为单位。

参数/返回值: seconds,存储获取的时间。

使用:

time_t now = time(nullptr);    

2、char *ctime(const time_t *timer):

函数描述:返回一个表示时间的字符串。

格式:

Www Mmm dd hh:mm:ss yyyy(Mon Apr 05 15:23:17 2021)

其中,Www表示星期,Mmm表示月份,dd表示天数,hh:mm:ss表示时间,yyyy表示年份。

参数:time_t类型的指针。

返回值: c字符串,包含可读格式的日期时间信息。

使用:

char* curr_time = ctime(&now); cout << curr_time <<endl;  // Mon Apr 05 15:23:17 2021    

3、struct tm *localtime(const time_t *timer):

函数描述:使用timer的值来填充tm结构。

参数:time_t类型的指针。

返回值: 返回指向tm结构的指针,本地时间。

使用:

tm* curr_tm = localtime(&now);

4、struct tm *gmtime(const time_t *timer):

函数描述:使用timer的值来填充tm结构。

参数:time_t类型的指针。

返回值: 返回指向tm结构的指针,GMT时间。

使用:

tm* curr_tm = gmtime(&now);    

5、char *asctime(const struct tm *timeptr):

函数描述:将tm结构体表示的时间返回为可读的字符串类型。

参数:tm结构体类型的指针。

返回值: c字符串,包含可读格式的日期时间信息。

使用:

char* curr_time2 = asctime(curr_tm);  

注:函数2 = 函数3/4 + 函数5; // 函数2实现的功能与3/4+5实现的一致。

6、size_t strftime(char *str, size_t maxsize, const char *format, const struct tm *timeptr):

函数描述:根据 format 中定义的格式化规则,格式化结构 timeptr 表示的时间,并把它存储在 str 中。

参数:

  • str:这是指向目标数组的指针,用来复制产生的 C 字符串。
  • maxsize:这是被复制到 str 的最大字符数。
  • format:指定的 C 格式字符串。

使用:

time_t now = time(nullptr);  
tm* curr_tm = localtime(&now);  // 返回的结构体存储位置未知,不知何时释放,因此推荐使用安全版本。  
char time[80] = {0};  
strftime(time, 80, "%Y-%m-%d %H:%M:%S", curr_tm);  

最后

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • C++引用的使用与const修饰符

    C++引用的使用与const修饰符

    这篇文章介绍了C++引用使用与const修饰符,引用是给已经定义的变量一个别名,可以简单理解成同一个变量的昵称,既然是昵称或者是别名,显然它和原本的变量名有着同样的效力,所以我们对别名进行修改,原本的变量值也一样会发生变化,下面来看看详细内容,需要的朋友可以参考下
    2021-11-11
  • C语言实现万年历小程序

    C语言实现万年历小程序

    这篇文章主要为大家详细介绍了C语言实现万年历小程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • 关于c语言指针的两处小tip分享

    关于c语言指针的两处小tip分享

    本篇文章是对c语言中指针的两处小tip进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++运算符重载与多继承及二义性详解

    C++运算符重载与多继承及二义性详解

    继友元知识过后,就到了今天的C++运算符重载的内容了,运算符重载是C++里比较重要的内容。这篇博文不会一下子讲完各种运算符重载,因为太多了了也不好吸收掌握,所以运算符重载我准备分多次记录和分享,那么接下来进入正文
    2022-11-11
  • C++实现对回收站里的文件进行操作的示例代码

    C++实现对回收站里的文件进行操作的示例代码

    这篇文章主要为大家详细介绍了C++如何使用代码对回收站里的文件进行操作,譬如文件的删除与恢复等,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴快跟随小编一起学习学习吧
    2023-06-06
  • C++小知识:不要节约代码行数

    C++小知识:不要节约代码行数

    今天小编就为大家分享一篇关于C++小知识:不要节约代码行数,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • C语言对对碰游戏源码分享

    C语言对对碰游戏源码分享

    这篇文章主要为大家分享了C语言对对碰游戏源码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • C++浅析类与对象的基础

    C++浅析类与对象的基础

    类和对象是两种以计算机为载体的计算机语言的合称。对象是对客观事物的抽象,类是对对象的抽象。类是一种抽象的数据类型;变量就是可以变化的量,存储在内存中—个可以拥有在某个范围内的可变存储区域
    2022-05-05
  • 详谈c++11 final与override说明符

    详谈c++11 final与override说明符

    下面小编就为大家带来一篇详谈c++11 final与override说明符。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • 浅谈c++中的stl中的map用法详解

    浅谈c++中的stl中的map用法详解

    下面小编就为大家带来一篇浅谈c++中的stl中的map用法详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10

最新评论