QT QDebug与QIODevice无法正常工作

时间:2013-09-29 08:22:38

标签: c++ qt qdebug

我希望我的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 Stream。 那么为什么没有输出存储在文件中?

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

1 个答案:

答案 0 :(得分:2)

使用此

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

或者这个

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

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

delete logger;

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