在Qt Creator应用程序输出中输出的Qt控制台应用程序的qDebug。

8

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

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

Application output

2个回答

7

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

为了完整起见:如果您想要在面板中看到所有输出而不是在控制台中,请在“项目-运行设置”中取消选中“在终端中运行”。


我知道...但我想要输出到两个不同的地方...这就是为什么它是调试输出。 - Eugene
很抱歉,您不能这样做。 - Bojan
3
我取消了“在终端中运行”的选项,但仍然看不到应用程序的任何输出。std::cout、qDebug 都没有输出。 - Dmitriy

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年以来已经进步,答案使用了已弃用的调用。 - Kenn Sebesta

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接