【问题标题】:QT QDebug with QIODevice not workingQT QDebug 与 QIODevice 不工作
【发布时间】:2013-09-29 08:22:38
【问题描述】:

我希望我的 QT 应用程序将某些日志存储在不同的文件中。 我一直在使用qDebug() << "LOG Messages" 来输出信息。 这种方法的问题是所有输出都将出现在同一个屏幕上,即使你是线程。 QDebug 类文档表明我可以制作一个 QDebug(QIODevice * dev) 以将任何 QIODEvice 作为存储数据的设备。所以我写了以下代码,但它不起作用:

QString logfilePath = "/var/log/1.log";
QFile * logfile = new QFile(logfilePath);
if(!logfile->open(QIODevice::WriteOnly|QIODevice::Append)){
    // There is an error
}else{
    QDebug * logger = new QDebug(logfile);
    *logger << "msg";
}

文件已创建,但文件中未存储任何信息。 我什至检查了 QDebug 代码,它看起来像是在 QIODevice 上创建了一个 TEXT 流。 那么为什么没有输出存储在文件中呢?

我也知道 qMessageInstaller 函数。但它对我不起作用,因为它是一个通用处理程序,我希望不同的线程将日志消息存储在不同的文件中。

【问题讨论】:

    标签: c++ qt qdebug


    【解决方案1】:

    使用这个

    *logger << "Hello!" << endl;
    

    或者这个

    *logger << "Hello!" << flush;
    

    记得删除记录器,它也会刷新流。

    delete logger;
    

    确保您也在不同的线程中写入不同的文件。

    【讨论】:

    • 由于测试流给出了文本,有没有办法刷新它?
    • @user1066991,是的,请查看变异答案。
    • 注意:这不是std::endl,而是来自QTextStreamendl(我学得很辛苦)
    猜你喜欢
    • 1970-01-01
    • 2012-11-06
    • 2018-07-21
    • 2015-08-15
    • 2023-04-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多