C#利用缓存分块读写大文件
C#利用缓存分块读写大文件,供大家参考,具体内容如下
在日常生活中,可能会遇到大文件的读取,不论是什么格式,按照储存文件的格式读取大文件,就会在Buffer中看到相关的文件头合内容,以一次.txt文件存取为例。
usingSystem.IO;
首先创建demo文件,此处文件大小没关系,只是演示
privatevoidbutton2_Click(objectsender,EventArgse)
{
using(FileStreamfsWrite=newFileStream(@"D:\1.txt",FileMode.Append))
{
stringtemp="";
for(inti=0;i<10000;i++)
{
temp+=i.ToString()+"/t";
}
byte[]m=System.Text.Encoding.UTF8.GetBytes(temp);
fsWrite.Write(m,0,temp.Length);
}
}
读取创建的文件
privatevoidReadtxt()
{
using(FileStreamfsRead=newFileStream(@"d:\2.txt,FileMode.Open"))
{
//剩余文件内容长度
longleftLength=fsRead.Length;
//buffersize
intbuffersize=1024;
//创建缓存数组
byte[]buffer=newbyte[buffersize];
intrNum=0;
intFileStart=0;
while(leftLength>0)
{
//设置文件流的读取位置
fsRead.Position=FileStart;
if(leftLength
写入文件后期,还牵扯到数据的拼接与处理
个人感觉,数据如果要按照一定格式拼接,可以通过改变每次读取的位置,来处理。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。