qDebug Qt 控制台应用程序输出到 Qt Creator 应用程序输出

Posted

技术标签:

【中文标题】qDebug Qt 控制台应用程序输出到 Qt Creator 应用程序输出【英文标题】:qDebug Qt console application to output to Qt Creator application output 【发布时间】:2012-07-30 23:54:44 【问题描述】:

如何在 Qt 控制台应用程序中使用 qDebug 输出到 Qt Creator “应用程序输出”窗口?目前 qDebug 写入控制台窗口,这会干扰非调试输出。

在 Qt GUI 应用程序中使用 qDebug 默认输出到应用程序输出窗口。

【问题讨论】:

【参考方案1】:

您可以将所有内容输出到控制台,也可以将所有内容输出到 Qt Creator 的应用程序输出面板。

为了完整起见:如果您想在面板中而不是控制台中显示所有输出,您可以在 Project->Run settings 中取消选中“Run in terminal”。

【讨论】:

我知道...但我想输出到两个不同的地方...这就是它的调试输出。 很遗憾你不能这样做。 我没有选中“在终端中运行”,但仍然看不到我的应用程序的任何输出。 std::cout, qDebug 不输出任何东西【参考方案2】:

要将 QDebug 重定向到多个位置,您可能需要编写一些代码,可能是这样的:

QList<QtMsgHandler> messageHandlers_;

static void messageDispatcher(QtMsgType type, const char *msg)

  foreach (QtMsgHandler callback, ::messageHandlers_)
    callback(type, msg);


static void messageLogger(QtMsgType type, const char *msg)

  QString output;
  switch (type) 
  case QtDebugMsg:    output = QString("mesage: %1\n").arg(msg); break;
  case QtWarningMsg:  output = QString("warning: %1\n").arg(msg); break;
  case QtCriticalMsg: output = QString("critical: %1\n").arg(msg); break;
  case QtFatalMsg:    output = QString("fatal: %1\n").arg(msg); break;
  default: return;
  

  QFile file("log.txt");
  if (file.open(QIODevice::WriteOnly | QIODevice::Append))
    QTextStream(&file) << output;


int main()

  ...
  ::messageHandlers_.append(messageLogger)
  qInstallMsgHandler(messageDispatcher);
  ...

【讨论】:

此代码不起作用。不确定是因为代码示例中的拼写错误(其中似乎至少有一个),还是因为 Qt 自 2013 年以来取得了进展并且答案使用了不推荐使用的调用。

以上是关于qDebug Qt 控制台应用程序输出到 Qt Creator 应用程序输出的主要内容,如果未能解决你的问题,请参考以下文章

在VS2008下做Qt,qDebug的内容输出到哪里去了?

用Qt Creator 编写GUI程序, 源代码用UTF-8编码, 如何用qDebug()输出中文?

QT5入门之12 - QDebug输出调试信息

解决 Fedora Linux 35 下 Qt 程序 qDebug() 无输出问题

解决 Fedora Linux 35 下 Qt 程序 qDebug() 无输出问题

Qt重定向qDebug,实现日志系统(QtDebugMsgQtInfoMsgQtWarningMsgQtCriticalMsgQtFatalMsg)