在Qt中,一般习惯使用qDebug信息进行输出和打印调试信息到console或者文件中,在qDebug中,也有一些小技巧,可以帮助我们更好的使用qDebug打印日志记录,本文分享了qDebug使用的一些小技巧。
有些时候是不是可能会遇见这样的事情,自己不知道在哪儿打印了一串debug信息,但是现在不知道在哪儿了,并且由于文件很多,比较难以寻找。本次提到的方法就可以解决这个问题。首先,要明白一件事,打印出行号、文件名一定要在调用qDebug时就知道当前位置,C语言是通过 __FILE__
__LINE__
这些东西得到的,而qDebug也是一样的方式,它是一个宏实现是这个样子的。
#define qDebug QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).debug
#define qInfo QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).info
#define qWarning QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).warning
#define qCritical QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).critical
#define qFatal QMessageLogger(QT_MESSAGELOG_FILE, QT_MESSAGELOG_LINE, QT_MESSAGELOG_FUNC).fatal
而其中
#define QT_MESSAGELOG_FILE __FILE__
#define QT_MESSAGELOG_LINE __LINE__
#define QT_MESSAGELOG_FUNC Q_FUNC_INFO
所以,qDebug 本身应该是支持了打印上下文信息的,但是为什么我们平时打印的信息没有呢?
这个是因为需要去设置一下message的pattern
设置pattern有两种方法:
qSetMessagePattern
函数
通过函数设置格式,例如: qSetMessagePattern("[%{type}]%{file}:%{line}\t%{time}\t%{function}\n%{message}")
QT_MESSAGE_PATTERN
环境变量
通过设置全局环境变量或者使用qputenv("QT_MESSAGE_PATTERN", "[%{type}]%{file}:%{line}\t%{time}\t%{function}\n%{message}");
的手法,来设置pattern
或者换个思路,qt为我们提供了一个handle
,使用 qInstallMessageHandler
设置
void msgHandle(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
printf("Debug: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function);
}
qInstallMessageHandler(msgHandle);
将qDebug输出到文件当中则是直接采用 qInstallMessageHandler
的思路来做,在这个函数中,将printf
改成fprintf
即可。
在qlogging.h
中有一段代码
#if defined(QT_NO_DEBUG_OUTPUT)
# undef qDebug
# define qDebug QT_NO_QDEBUG_MACRO
#endif
意味着其实当定义了上面的qDebug宏后,其实下面还有宏条件重新定义,展开看看 QT_NO_QDEBUG_MACRO
则是
#define QT_NO_QDEBUG_MACRO while (false) QMessageLogger().noDebug
所以,我们在编译时,加入一个宏即可(pro文件直接写法如下:)
DEFINES += QT_NO_DEBUG_OUTPUT