1

有没有办法告诉应用程序只打印qDebug或只打印qFatal消息?

4

1 回答 1

2

就在这里。您可以使用 qInstallMessageHandler. 这看起来像这样(来自 Qt 文档):

    void myMessageOutput(QtMsgType type, const QMessageLogContext &context, 
const QString &msg)
    {
        QByteArray localMsg = msg.toLocal8Bit();
        switch (type) {
        case QtDebugMsg:
            fprintf(stderr, "Debug: %s (%s:%u, %s)\n", localMsg.constData(), 
            context.file, context.line, context.function);
            break;
        case QtWarningMsg:
            fprintf(stderr, "Warning: %s (%s:%u, %s)\n", localMsg.constData(),
            context.file, context.line, context.function);
            break;
        case QtCriticalMsg:
            fprintf(stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), 
            context.file, context.line, context.function);
            break;
        case QtFatalMsg:
            fprintf(stderr, "Fatal: %s (%s:%u, %s)\n", localMsg.constData(), 
            context.file, context.line, context.function);
            abort();
        }
    }

    int main(int argc, char **argv)
    {
        qInstallMessageHandler(myMessageOutput);
        QApplication app(argc, argv);
        ...
        return app.exec();
    }

让您 100% 控制 qDebug 和其他 q* *输出函数的工作方式。

于 2013-08-25T09:26:50.873 回答