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#利用缓存分块读写大文件