gpt4 book ai didi

c++ - QT QDebug 与 QIODevice 不工作

转载 作者:行者123 更新时间:2023-11-28 03:08:33 25 4
gpt4 key购买 nike

我希望我的 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 上创建了一个文本流。那么为什么文件中没有存储输出?

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

最佳答案

使用这个

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

或者这个

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

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

delete logger;

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

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

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com