Qt 日志功能

Qt  之日志功能


enum LOG_LEVLE
{
	LOG_DEBUG = 0,
	LOG_WARNING = 1,
	LOG_ERROR = 2,
	LOG_FATAL = 3
};

#define LOGLEVEL	LOG_DEBUG

void logViewOutPut(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
	if (type < LOGLEVEL)
		return;

	QString strMsg;
	switch (type)
	{
	case QtDebugMsg:
		strMsg = QString("  Debug  ");
		break;
	case QtWarningMsg:
		strMsg = QString("  Warning  ");
		break;
	case QtCriticalMsg:
		strMsg = QString("  Critical  ");
		break;
	case QtFatalMsg:
		strMsg = QString("  Fatal  ");
		abort();
	default:
		break;
	}
	QByteArray localMsg = msg.toLocal8Bit();
	QString strTime = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss");

	QString message = QString("File:(%1) Line:(%2) Func:(%3)  MSG:(%4)").arg(QString(context.file)).arg(QString::number(context.line)).arg(QString(context.function)).arg(QString(localMsg.constData()));
	QString str = strTime + strMsg + message;

	static QMutex mutex;
	mutex.lock();
	QFile file("log.txt");
	file.open(QIODevice::WriteOnly | QIODevice::Append);

	QTextStream stream(&file);
	stream << str << "\r\n";

	file.flush();
	file.close();
	mutex.unlock();
}

int main(int argc, char *argv[])
{
	qInstallMessageHandler(logViewOutPut);

	QApplication a(argc, argv);
	Mainwindow w;
	w.show();
	return a.exec();
}

在main()中添加上面的代码就可以实现一个简单的日志功能,程序中调用qDebug等就可以实现日志输出。
qInstallMessageHandle 有点类似与Qt的EventFilter,调试信息先汇总到注册的函数里面,按照代码执行。相当于重定向输出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值