Qt中自定义qDebug打印信息的宏(文件名,行数,函数名,日期,时间等前缀)并取消打印

使用qDebug()打印信息时,默认打印"<<"符号后面的信息。

通过自定义宏,可以额外打印文件名,行数,函数,日期、时间等前缀,方便快速定位调式信息的位置。

同时,可以定义宏取消打印输出。

代码如下:

复制代码
#include <QDebug>        //注意,头文件一定要添加
#define XLOG_EN
#ifdef  XLOG_EN
    #define xLog qDebug() << "[" << __FILE__ << ":" << __LINE__ << ":" << __func__ << __DATE__ << __TIME__<< "]"
#else
    #define xLog    QT_NO_QDEBUG_MACRO()
#endif
 
int main(int argc, char *argv[])
{
    xLog << "Hello World!";
    return 1;
}

程序运行,将会打印如下内容:

../main.cpp : 7 : main Oct 16 2024 15:47:17 \] Hello World! __func__:当前的函数名;//同QT_MESSAGELOG_FUNC或Q_FUNC_INFO或__FUNCTION__ __DATE__:当前的编译日期; __TIME__:当前编译时间; __FILE__:当前源文件路径及文件名;//同QT_MESSAGELOG_FILE __LINE__:当前源代码行号;//同QT_MESSAGELOG_LINE 注意:__DATE__,__TIME__打印的是编译的时间,不是程序运行到打印时的时间,我们可以简单使用Qt自带的QDateTime实现,如下: #include //要添加的头文件 #define MYLOG qDebug() << "[" << __FILE__ << ":" << __LINE__ << ":" << __func__ << QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss:zzz")<< "]" 程序运行输出信息如下: \[ ../main.cpp : 7 : main "2024-10-16 16:10:20:398"\] Hello World! 如果屏蔽定义: //#define XLOG_EN 则调试的打印信息就不会输出了! 当然,打印前缀可以使用其它固定的字符串。

相关推荐
特种加菲猫11 小时前
二叉搜索树:数据世界的“快速寻路指南”
开发语言·c++
特种加菲猫11 小时前
STL关联容器:Set/Multiset与Map/Multimap详解
开发语言·c++
我滴老baby11 小时前
0基础速通Python+AI|2026热门轻量化玩法全攻略:从入门到实战,3天搞定AI应用开发
开发语言·人工智能·python
一个天蝎座 白勺 程序猿11 小时前
Python(29)Python生成器函数深度解析:asyncio事件循环的底层实现与异步编程实战
开发语言·python
2zcode11 小时前
原创文档:基于MATLAB的线性预测编码变声器系统
开发语言·matlab·语音识别
七夜zippoe11 小时前
Python RESTful API设计终极指南:从理论到企业级实战
开发语言·python·http·pandas·restful api
lly20240611 小时前
Highcharts 配置说明
开发语言
车位涂鸦11 小时前
在线浏览“秀人网合集”的新思路:30 行 Python 把封面图链接秒变本地可点图库
开发语言·python
中草药z11 小时前
【测试基础】Python 核心语法,一篇搞定测试脚本开发基础
开发语言·笔记·python·学习·测试·语法
lsx20240612 小时前
XHR 请求:详解与使用
开发语言