我在用QT在linux下拷贝文件,这个文件还比较大,要6秒钟左右,于是我就用log4qt去记录时间,发现我的文件明明拷贝成功了,但是日志却要等一段时间才记录进去。于是就发现了linux下面写文件是先写到缓冲区,再写进磁盘或者SD卡,这样有利于提高效率
bool ok = QFile::copy(fileInfo.filePath(), QString("../../")+name);
if(ok)
{
logcopy->info("copy file success");
system("sync");
emit copySuccess(version);
}
所以你写入日志之后加入system("sync")。这样操作的意思就是linux下执行sync命令,意思将缓冲区的内容强制写入磁盘
最后
以上就是忧心汉堡最近收集整理的关于Qt写文件出现延时写入的全部内容,更多相关Qt写文件出现延时写入内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复