c#利用缓存分块读写大文件

  

c#利用缓存分块读写大文件,供大家参考,具体内容如下
  

  

在日常生活中,可能会遇到大文件的读取,不论是什么格式,按照储存文件的格式读取大文件,就会在缓冲区中看到相关的文件头合内容,以一次。txt文件存取为例。
  

  
  

使用先;      

首先创建演示文件,此处文件大小没关系,只是演示
  

        私人空间button2_Click(对象发送方,EventArgs e)   {   使用(fsWrite=new FileStream文件流(@“D: \ 1。txt”, FileMode.Append))   {   字符串temp=" ";   for (int i=0;我& lt;10000;我+ +)   {   临时+=i.ToString () +“/t”;      }   m=System.Text.Encoding.UTF8 byte []。GetBytes(临时);   fsWrite。写(m 0 temp.Length);   }   }      

读取创建的文件
  

        私人空间Readtxt ()   {   使用(fsRead=new FileStream文件流(@“d: \ 2. txt, FileMode.Open”))   {//剩余文件内容长度   长leftLength=fsRead.Length;//buffersize   int buffersize=1024;//创建缓存数组   缓冲区byte[]=新的字节(buffersize);   int rNum=0;   int FileStart=0;   而(leftLength比;0)   {//设置文件流的读取位置   fsRead。位置=FileStart;   如果(leftLength & lt;buffersize)   {   rNum=fsRead。读(缓冲区,0,Convert.ToInt32 (leftLength));   }   其他的   {   rNum=fsRead。读(缓冲区,0,最大长度);   }   如果(rNum==0)   {   打破;   }   fileStart +=rNum;   leftLength -=rNum;//字节转换   字符串味精=System.Text.Encoding.UTF8.GetString(缓冲);//byte [] myByte=System.Text.Encoding.UTF8.GetBytes(味精);////写入文件   使用(fsWrite=new FileStream文件流(@“d: \ 2。txt, FileMode.Append))//处理完成再追加   {   fsWrite。写(myByte 0 myByte.Length);   }   }   fsRead.Close ();   }   }      

写入文件后期,还牵扯到数据的拼接与处理
  

  

个人感觉,数据如果要按照一定格式拼接,可以通过改变每次读取的位置,来处理。
  

  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

c#利用缓存分块读写大文件