• Qt linux文件同步写入


     因为linux 系统机制问题,文件的创建和写入并不会直接写入硬盘。而是先写入缓存,当系统要关闭或须要时才写入硬盘。为防止突然掉电,应将缓存中的文件及时同步到硬盘上去。

    linux 下的sync 命令具有数据同步功能。我们能够在Qt程序中调用该命令。


         附:sync 命令说明

    sync命令 linux同步数据命令
    格式: sync 
    用途:更新 i-node 表,并将缓冲文件写到硬盘中。
    功能:sync命令是在关闭Linux系统时使用的。 用户须要注意的是,不能用简单的关闭电源的方法关闭系统,由于Linux象其它Unix系统一样。在内存中缓存了很多数据,在关闭系统时须要进行内存数据与硬盘数据的同步校验,保证硬盘数据在关闭系统时是最新的,仅仅有这样才干确保数据不会丢失。一般正常的关闭系统的过程是自己主动进行这些工作的,在系统执行过程中也会定时做这些工作。不须要用户干预。 sync命令是强制把内存中的数据写回硬盘,以免数据的丢失。

    用户能够在须要的时候使用此命令。
    sync 命令执行 sync 子例程。假设必须停止系统,则执行 sync 命令以确保文件系统的完整性。

    sync 命令将全部未写的系统缓冲区写到磁盘中。包括已改动的 i-node、已延迟的块 I/O 和读写映射文件。


    程序源代码:

    使用Qt自带类QSettings
    //保存
    void MainWindow::on_pushButton_clicked()
    {
           QString string="中华人民共和国 hello world!

    "; QSettings setting("/mnt/nand1-2/dd/config.ini",QSettings::IniFormat);//生成配置文件 setting.beginGroup("config");//beginGroup与以下endGroup 相相应,“config”是标记 setting.setValue("page",QVariant(string)); setting.setValue("site",QVariant("http://www.cppblog.com/gaimor/")); setting.setValue("maker",QVariant("Gaimor")); setting.endGroup(); //强制将内存数据写入硬盘 system("sync"); //清空 ui->lineEdit->clear(); } //读配置文件 QSettings setting("/mnt/nand1-2/dd/config.ini",QSettings::IniFormat);//读配置文件 setting.beginGroup("config"); QString page=setting.value("page").toString(); ui->plainTextEdit->appendPlainText(page); 使用C库实现 //C函数库 void MainWindow::on_pushButton_5_clicked() { FILE *fd; FILE *fd1; char str[LENGTH]; fd = fopen("/mnt/nand1-2/dd/file.txt", "w+"); /* 创建并打开文件 */ if (fd) { fputs("Hello, create file success!", fd); /* 写入Hello, software weekly字符串 */ fclose(fd); } //强制将内存数据写入硬盘 system("sync"); fd1 = fopen("/mnt/nand1-2/dd/file.txt", "r"); fgets(str, LENGTH, fd1); /* 读取文件内容 */ ui->textBrowser->insertPlainText(str); printf("%s ", str); fclose(fd1); }



  • 相关阅读:
    1202诗人基本介绍&诗人画像
    1205人物关系优化&诗人轨迹
    把SQL Server 2000 表中的自动编号Id重新开始排列
    一个一直都不明白的东西今天知道了。关于sqlserver2000自动执行。
    服装打版界的扛把子ET自定义操作
    手把手教你搭建集中式版本控制系统SVN服务器
    分享一次实用的爬虫经验
    盘点CSV文件在Excel中打开后乱码问题的两种处理方法
    盘点服装设计所经常性使用的软件ET(下篇)
    sql 每个企业选择一条产品
  • 原文地址:https://www.cnblogs.com/yangykaifa/p/7196871.html
Copyright © 2020-2023  润新知