c++ - Qt 中的自定义和默认消息处理程序

标签 c++ debugging qt logging

我想在将消息记录到除 qDebug 之外的日志文件时使用默认的 Qt 消息处理程序。 这是我的解决方案,您有什么建议或此实现可能存在的问题是什么?

标题:

#ifndef QLOGGER_H
#define QLOGGER_H

#include <QtCore/QObject>
#include <QtCore/QFile>
#include <QtCore/QDateTime>

class QLogger : public QObject
{
Q_OBJECT

public:
    QLogger();
   ~QLogger();

    static void start();
    static void finish();
    static QString filename;

private:
    static void myloggerfunction(QtMsgType type, const char *msg);

};

#endif // QLOGGER_H

来源:

#include <QTextStream>
#include <QDateTime>
#include <QDir>
#include <iostream>

#include "qlogger.h"

using namespace std;

QString QLogger::filename=QString("log.txt");

QLogger::QLogger()
{
}

QLogger::~QLogger()
{
}

void QLogger::start()
{
    qInstallMsgHandler(myloggerfunction);
}

void QLogger::finish()
{
    qInstallMsgHandler(0);
}

void QLogger::myloggerfunction(QtMsgType type, const char *msg)
{
    QDir dir;
    dir.cd("LOG");

    QFile logFile(filename);

    if (logFile.open(QIODevice::Append | QIODevice::Text))
    {
        QTextStream streamer(&logFile);

        switch (type){
                 case QtDebugMsg:
                     finish();
                     qDebug(msg);
                     break;
                 case QtWarningMsg:
                     streamer << QDateTime::currentDateTime().toString() <<" Warning: " << msg <<  "\n";
                     finish();
                     qWarning(msg);
                     break;
                 case QtCriticalMsg:
                     streamer << QDateTime::currentDateTime().toString() <<" Critical: " << msg <<  "\n";
                     finish();
                     qCritical(msg);
                     break;
                 case QtFatalMsg:
                     streamer << QDateTime::currentDateTime().toString() <<" Fatal: " << msg <<  "\n";
                     finish();
                     qFatal(msg);
                     break;
        }
        logFile.close();
    }
    start();
}

最佳答案

Afaik 这是行不通的,您正在将消息处理函数实现为对象的成员函数 qInstallMessageHandler 采用的函数签名是 void myMsgHandler(QtMsgType,常量字符 *);

您可以将该函数实现为一个普通的独立函数,也可以使用带有静态访问器的单例,例如

void msgHandler(QtMsgType type, const char * msg)
{
   Logger::instance()->handleMessage(type,msg);
}

class Logger
{
  static Logger* instance() {... }
  void handleMessage(QtMsgType type, const char* msg) { ... }
}

这为您提供了一个用于qInstallMsgHandler 的函数和一个包装日志记录的对象

关于c++ - Qt 中的自定义和默认消息处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4335331/

相关文章:

C++ : How to bind inherited methods only to parent classes?

android - 生成文件调试 : which file/line calls to a command?

c - 如何调试 "INT_MAX undeclared"

c++ - 如何使用槽调用小部件的函数?

linux - 如何在 Qt 中设置嵌入式 MySQL 客户端

c++ - 如何使用原子头 C++

c++ - 是否可以控制源文件中的 cl.exe 选项?

C++释放内存传递给函数中的参数或将其留给调用者

java - 无法使用任何调试器连接到 Glassfish

python - 为什么 SLOT ('insertColumn()' ) 在 PyQt 绑定(bind)中失败?