我希望我的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函数。但这对我不起作用,因为它是一个通用处理程序,我希望使用不同的线程将日志消息存储在不同的文件中。

最佳答案

用这个

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


或这个

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


记住要删除记录器,这也会刷新流。

delete logger;


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

关于c++ - QT QDebug与QIODevice不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19075912/

10-11 00:45