首页 > 解决方案 > qDebug 不输出任何东西

问题描述

我刚刚开始使用 Qt Creator V4.13 和 Qt V5.15.1 学习 Qt,当我使用 qDebug()、qInfo()、qWarning() 和 qCritical() 时,它不会在应用程序输出中显示任何内容。

[编辑] 我检查了“在终端中运行”,然后清理并重建项目,它现在使用“qtcreator_process_sub”运行,并带有 qDebug 所需的输出。

。轮廓

    QT       += core gui

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

CONFIG += c++11

# You can make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

SOURCES += \
    main.cpp \
    mainwindow.cpp

HEADERS += \
    mainwindow.h

FORMS += \
    mainwindow.ui

TRANSLATIONS += \
    ToDo_ar_EG.ts

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

MainWindow.h 文件

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
Q_OBJECT

public:
MainWindow(QWidget *parent = nullptr);
~MainWindow();
private slots:
void addTask();

private:
Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

MainWindow.cpp 文件

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "QtWidgets/QPushButton"
#include "QDebug"
#include <iostream>

MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
, ui(new Ui::MainWindow)
{
ui->setupUi(this);
connect(ui->addTaskButton, &QPushButton::clicked, this, &MainWindow::addTask);
}

MainWindow::~MainWindow()
{
delete ui;
}

void MainWindow::addTask()
{
qDebug()<<"Debug button";
qInfo()<<"Information output";
qWarning()<<"Warning output";
qCritical()<<"Critical output";
}

我花了两天时间在 Google 上搜索,但所有答案都是关于未定义 QT_NO_DEBUG_OUTPUT 但它已定义。我尝试过的:包括“QtDebug”而不是“qDebug”创建带有内容的 qtlogging.ini:-

[Rules]
*.debug=true

每次编辑后都尝试了一个干净的构建(干净和重建项目)

眼镜:

Arch Linux(系统是最新的我刚刚更新了它)

V4.13 和 Qt V5.15.1

CMake V3.18.2

制作V4.3

QMake V3.1

标签: c++qt

解决方案


要查看 lggoing 输出,您需要:

  1. 将您的项目配置为具有控制台
  2. 通过在构建时定义 QT_NO_DEBUG 确保 qDebug() 未被禁用(切换到调试构建)。
  3. 确保系统/usr 配置文件没有禁用日志记录。
  4. 如果加入现有项目,请检查是否qInstallMessageHandler()已调用 a,在这种情况下,他的输出可能会被重定向到某个地方。
  5. 如果加入现有项目,请确保调用不会抑制日志记录setSeverity(在新的 Qt Creator 项目中不是问题)。

第 1 步:要为您的应用程序配置控制台,请添加

CONFIG += console

到您的 .pro 文件,然后重新运行 qmake 并重建。或者,在 Qt Creator 提供的运行配置 gui 中启用“使用控制台运行”。

第 2 步:从“发布”版本切换到“调试”版本

为此,您可以使用左下角的 Qt Creator 的 gui。这CONFIG会在 .proj 文件中从“发布”切换到“调试”。其中,除其他外,告诉 qmake 不要生成使用-DQT_NO_DEBUG. 因为那会禁用qDebug级别日志记录。或者,自己编辑 .pro 文件并重新运行 qmake,然后重新编译。

第 3 步:检查日志记录配置文件

由于qInfo()在您的系统上也不起作用,因此此步骤在您的特定情况下可能不是问题,但通常可能是一个问题。

可以通过系统和/或日志配置文件中设置的规则有选择地启用或禁用日志记录。自 2015 年以来qDebug(),默认情况下,主要 Linux 发行版(ubuntu、fedora22+)通过qtlogging.ini包含在发行版 Qt5 软件包中的系统范围禁用级别。

在我的系统上,这意味着我有/usr/share/qt5/qtlogging.ini

$  cat /usr/share/qt5/qtlogging.ini
[Rules]
*.debug=false

要在命令行上手动覆盖它,您可以从命令行设置环境变量:

$ export QT_LOGGING_RULES='*.debug=true'

$ ./my_program

如果您想保持全局禁用调试输出,您还可以在 Qt Creator 中编辑“构建环境”,但在 Qt Creator 中运行时可以看到它。

我建议您阅读QLoggingCategory - 日志记录规则,了解如何配置。另请参阅fedora 票证,了解默认情况下禁用的更改。


推荐阅读