Qt 之QTemporaryFile用法(创建临时文件)

138 篇文章 192 订阅

前言

上一篇文章中介绍了如何使用QTemporaryDir 来创建临时目录
- Qt之QTemporaryDir用法(创建临时目录)
而今天要说的是如何创建一个临时文件,可以安全的写入,并且可以自动删除该文件,使用 Qt 自带的类QTemporaryFile,其实和QTemporaryDir类似,都是同样的用法。

QTemporaryFile

该QTemporaryFile类是一个临时文件操作的I / O设备。

QTemporaryFile用于安全地创建唯一的临时文件。该文件本身是通过调用open()创建的。临时文件的名称保证是唯一的(保证不覆盖现有文件),并且该文件随后会在销毁QTemporaryFile对象后被删除。这是避免将数据存储在临时文件中的应用程序数据损坏。文件名是自动生成的,或者是根据传递给QTemporaryFile的构造函数的模板创建的。
例如:


// Within a function/method...
QTemporaryFile file;
if (file.open()) {
    // file.fileName() returns the unique file name
}
// The QTemporaryFile destructor removes the temporary file
// as it goes out of scope.

调用close()后重新打开QTemporaryFile是安全的。只要QTemporaryFile对象本身没有被破坏,唯一的临时文件就会存在,并由QTemporaryFile在内部保持打开状态。

通过调用fileName()可以找到临时文件的文件名。请注意,这仅在文件首次打开后才定义; 该函数在此之前返回一个空字符串。

临时文件将具有名称的一些静态部分以及计算为唯一的一部分。默认文件名将由QCoreApplication :: applicationName()(否则qt_temp)确定,并将被放置到由QDir :: tempPath()返回的临时路径中。如果指定了自己的文件名,默认情况下相对文件路径不会被放置在临时目录中,而是相对于当前工作目录。

指定的文件名可以包含以下模板XXXXXX(六个大写“X”字符),它将被文件名的自动生成部分替换。
请注意,该模板区分大小写。如果模板不存在于文件名中,QTemporaryFile将生成的部分追加到给定的文件名中。

常用成员函数

  • void setAutoRemove(bool b)
    设置是否为自动删除模式。
    自动删除功能默认为开启。
    如果将此属性设置为false,确保应用程序提供了一种方法,在文件不再需要时将其删除,包括将责任传递给另一个进程。始终使用fileName()函数来获取名称,并且永远不要猜测QTemporaryFile生成的名称。
    在某些系统上,如果在关闭文件之前未调用fileName(),则无论此属性的状态如何,都可以删除临时文件。不应该依赖此行为,因此应用程序代码应该调用fileName()或保持启用自动删除功能。

  • void QTemporaryFile :: setFileTemplate(const QString&name)
    将文件名称的静态部分设置为名称。如果文件模板包含将自动替换为文件名的唯一部分的XXXXXX,否则文件名将根据指定的静态部分自动确定。
    如果name包含相对文件路径,则路径将相对于当前工作目录。如果你想使用系统的临时目录,你可以使用QDir :: tempPath()来构造名字。

  • bool open()
    一个QTemporaryFile将永远被打开了QIODevice::ReadWrite 模式,这可以方便地访问文件中的数据。该函数在成功时将返回true,并将fileName()设置为使用的唯一文件名。

静态函数

  • QTemporaryFile * createNativeFile(QFile &file)
  • QTemporaryFile * createNativeFile(const QString &fileName)
    如果文件已经是一个本地文件,然后QTemporaryFile在创建一个QDir::tempPath(),内容的文件复制到它,并返回一个指向该临时文件。如果文件已经是本机文件,则不做任何事并返回。

例如:

QFile f(":/resources/file.txt");
QTemporaryFile::createNativeFile(f); // Returns a pointer to a temporary file

QFile f("/users/qt/file.txt");
QTemporaryFile::createNativeFile(f); // Returns 0

##示例

    //QTemporaryFile示例
    QString tmpname = QDir::homePath() + QDir::separator() + QCoreApplication::applicationName() + "_XXXXXX." + "txt";
    QTemporaryFile tmpFile(tmpname);

    tmpFile.setAutoRemove(false);
    if(tmpFile.open()){
        qDebug() << __FUNCTION__ << tmpFile.fileTemplate();
        qDebug() << __FUNCTION__ << tmpFile.fileName();
    }

    QFile f(tmpFile.fileName());
    bool ok = QTemporaryFile::createNativeFile(f);//如果文件存在,返回 false
    qDebug() << __FUNCTION__ << ok;

//    tmpFile.remove();

注意,这里setAutoRemove(false),特意将该属性设置为false,因为默认是自动删除的,设置 false 后不需要的时候可以手动remove.
运行结果:

Widget "/Users/lyy/QTemporaryFileTest_XXXXXX.txt"
Widget "/Users/lyy/QTemporaryFileTest_L32420.txt"
Widget false

当再次通过静态函数去创建文件的时候QTemporaryFile::createNativeFile,由于上面已经创建过该文件,所以返回 false。

更多参考:http://doc.qt.io/qt-5/qtemporaryfile.html

  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luoyayun361

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值