7. QFile读写文件的基本操作「建议收藏」

7. QFile读写文件的基本操作「建议收藏」QFile的基本读写操作

大家好,又见面了,我是你们的朋友全栈君。

1. 小文件文件的读写

1.1 读取文件中所有的数据

	QFile file(fileName); // fileName文件的路径
    if(file.open(QIODevice::ReadOnly))  // 以读写的方式打开文件
    	return ;	
    QByteArray data = file.readAll();  //方式1. 将文件的数据全部读取出来
    int fileSize = file.size();   	   // 获取文件的长度(单位:字节)
    data = file.read(fileSize);        // 方式2. 将文件的所有数据读取出来
    // 从指定的位置开始读取
	file.seek(100) // 这是设置从100的位置读取
	data = file.read(1000) // 从100的位置读取1000个字节
    file.close();                      // 使用完毕把文件关闭

1.2 一行一行的读取文件的数据

	QFile file(fileName); // fileName文件的路径
    if(file.open(QIODevice::ReadOnly))  // 以读的方式打开文件
    	return ;
    while(!file.atEnd()) // 判断文件是否结束
    { 
   
        // 每读取一行数据,游标seek会自动往下跳,所以当seek到达末尾是atEnd()返回true
    	QByteArray data =  file.readLine();  
    }
    file.close();

1.3 将数据写入文件中

	QFile file(fileName); // fileName文件的路径
    if(file.open(QIODevice::WriteOnly))  // 以写的方式打开文件
    	return ;
   QByteArray data ;
   data.resize(10);
   memset(data.data(),0x00,data.size());
   file.write(data);
   file.close();

1.4 通过内存映射读写文件

uchar *QFileDevice::map(qint64 offset, qint64 size, MemoryMapFlags flags = NoOptions)
  1. 从offset开始将文件大小字节映射到内存中。为了使映射成功,应该打开一个文件,但在映射内存之后,文件不需要保持打开状态。当QFile被销毁或使用此对象打开一个新文件时,任何未被取消映射的映射将自动取消映射。
  2. 映射将具有与文件相同的打开模式(读和/或写),除非使用MapPrivateOption,在这种情况下,总是可以写入映射的内存。
  3. 返回一个指向内存的指针,如果有错误则返回0。
	QFile file(fileName); // fileName文件的路径
    if(file.open(QIODevice::WriteOnly))  // 以写的方式打开文件
    	return ;
    uchar* pfile = file.map(0, file.size());  // 返回一个指向内存的指针,如果有错误则返回0
    if(pfile)
    { 
   
    	// do work 
    	// memcpy(pfile,data.data(),size); // 写入数据
    	// memcpy(data.data(),pfile,size); // 读取数据
    	file.unmaps(pfile); // 取消映射 其实QFile对象被摧毁或者打开一个新的文件会自动取消映射
	}
	file.close();

2. 大文件的读写

在进行大文件读写是采用分段读写的思想,将大文件所有拆成一块一块的读写。

	QFile file(fileName); // fileName文件的路径
    if(file.open(QIODevice::WriteOnly))  // 以写的方式打开文件
    	return ;
    qint64 fileSize = file.size(); // 文件的长度
    int readSize = 1024*1024 ;  // 每一次读取的数据长度,可以自由设置
    // file.pos()获取文件游标的位置
    while(!file.atEnd())  
    { 
   
    	QByteArray data = file.read(readSize )
    	
    } 
    file.close();
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136733.html原文链接:https://javaforall.net

(2)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python中用turtle画一个圆形(pythonturtle教程)

    最近发现一个很有意思的画图的python库,叫做turtle,这里先说下用turtle这个库来实现用正方形画圆的思路。每次都用乌龟(turtle)来画出一个正方形,然后通过旋转3°后,继续画一样的正方形,在通过120次循环后就实现了完整的圆,这里当然也可以用其他的角度和次数,只要能完成360度就可以了。先看完成的图形和代码。代码如下:importturtlewindow=turtle.Scr…

    2022年4月14日
    346
  • Centos7下Rinetd安装与应用[通俗易懂]

    转自http://www.cnblogs.com/zhenyuyaodidiao/p/5540209.htmlLinux下做地址NAT有很多种方法。比如haproxy、nginx的4层代理,linux自带的iptables等都能实现。haproxy、nginx就不说了,配置相对简单;iptables配置复杂,概念也比较多DNAT、SNAT、PREROUTING、POSTROUTING等等。其实

    2022年4月17日
    80
  • Python 网络爬虫入门详解

    什么是网络爬虫     网络爬虫又称网络蜘蛛,是指按照某种规则在网络上爬取所需内容的脚本程序。众所周知,每个网页通常包含其他网页的入口,网络爬虫则通过一个网址依次进入其他网址获取所需内容。优先申明:我们使用的python编译环境为PyCharm 一、首先一个网络爬虫的组成结构:爬虫调度程序(程序的入口,用于启动整个程序) url管理器(用于管理未爬取得url及已经爬…

    2022年4月5日
    38
  • 构造函数的作用和特点[通俗易懂]

    构造函数的作用和特点[通俗易懂] 1. 构造函数的作用        构造函数主要用来在创建对象时完成对对象属性的一些初始化等操作, 当创建对象时, 对象会自动调用它的构造函数。一般来说, 构造函数有以下三个方面的作用:            ■ 给创建的对象建立一个标识符;            ■ 为对象数据成员开辟内存空间;            ■ 完成对象数据成员的初始化。2. 默认构造函数      …

    2022年9月7日
    1
  • signature=f382e962eb5d4f9443ff87189d12babf,CiteSeerX — from an observational study design. J Epidemi…

    signature=f382e962eb5d4f9443ff87189d12babf,CiteSeerX — from an observational study design. J Epidemi…AbstractLetterstotheEditor457outcomethanadirectinterventionbecauseofthespecificpathwayaffectedbythevariant,suchastheeffectofkringleIVtype2sizepolymorphismsonlipoprotein…

    2022年5月31日
    40
  • 执行力与领导力

    执行力与领导力

    2021年8月20日
    59

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号