深度
本文主要分析Windows平台,Mac、Linux暂不涉及
本文只分析到Win32 API/Windows Com组件/STL库函数层次,再下层代码不做探究
本文QT版本5.15.2
类关系图
QTemporaryFile继承QFile
QFile、QSaveFile继承QFileDevice
QFileDevice继承QIODevice
QIODevice、QFileSystemWatcher继承QObject
QLockFile、QFileInfo、QDir、QFileSelector无任何继承关系
QObject中有一指向QObjectData指针d_ptr。d_ptr是保护成员变量,这意味着每个子类可以修改d_ptr内容。在QObject中d_ptr指向QObjectPrivate,
QIODevice中d_ptr指向QIODevicePrivate
QFileDevice中d_ptr指向QFileDevicePrivate
QFile中d_ptr指向QFilePrivate
QTemporaryFile中d_ptr指向QTemporaryFilePrivate
QFileInfo、QDir、QLockFile不继承QObject,因此没有指向QObjectData指针d_ptr。但是各自同样声明了d_ptr变量指向各自的private类
QFileInfo中d_ptr指向QFileInfoPrivate
QDir中d_ptr指向QDirPrivate
QLockFile中d_ptr指向QLockFilePrivate
启发:
这种Private类书写方式适合场景是导出接口稳定、不想公开内部实现细节、内部能够灵活修改
可以用在付费插件、软件逆向等使用场景
QSaveFile
作用
提供了一个用于安全写入文件的接口。无论程序正在写入文件时发生崩溃还是断电等情况,目标文件必定是完整的,要么是修改前的文件,要么是修改后的文件,不会出现数据紊乱。
原理
写入时先写到临时文件中,待写入完成后将目标文件替换成临时文件
使用示例
#include <QSaveFile>
#include <QByteArray>
int main(int argc, char* argv[])
{
QSaveFile file("D:/1.txt");
if (file.open(QIODevice::WriteOnly))
{
file.write("Hello QFile!");
}
file.commit();
return 0;
}
主要函数调用流程及原理
QSaveFile::open
打开文件
QSaveFile::commit
将修改的内容提交。其实就是让临时文件替换目标文件
写到最后
目前先写到这,诸位无论是有什么意见或建议都可以写到评论区,下来一起探讨