C#利用缓存分块读写大文件
程序员文章站
2023-11-01 09:21:46
c#利用缓存分块读写大文件,供大家参考,具体内容如下
在日常生活中,可能会遇到大文件的读取,不论是什么格式,按照储存文件的格式读取大文件,就会在buffer中看到相关...
c#利用缓存分块读写大文件,供大家参考,具体内容如下
在日常生活中,可能会遇到大文件的读取,不论是什么格式,按照储存文件的格式读取大文件,就会在buffer中看到相关的文件头合内容, 以一次.txt文件存取为例。
using system.io;
首先创建demo文件,此处文件大小没关系,只是演示
private void button2_click(object sender, eventargs e) { using (filestream fswrite = new filestream(@"d:\1.txt", filemode.append)) { string temp = ""; for (int i = 0; i < 10000;i++ ) { temp += i.tostring()+"/t"; } byte [] m = system.text.encoding.utf8.getbytes (temp); fswrite.write(m, 0, temp.length); } }
读取创建的文件
private void readtxt() { using (filestream fsread = new filestream(@"d:\2.txt,filemode.open")) { //剩余文件内容长度 long leftlength = fsread.length; //buffersize int buffersize = 1024; //创建缓存数组 byte[] buffer = new byte[buffersize]; int rnum = 0; int filestart = 0; while(leftlength > 0) { //设置文件流的读取位置 fsread.position = filestart ; if (leftlength < buffersize) { rnum = fsread.read(buffer, 0, convert.toint32(leftlength)); } else { rnum = fsread.read(buffer, 0, maxlength); } if (rnum == 0) { break; } filestart += rnum; leftlength -= rnum; //字节转换 string msg = system.text.encoding.utf8.getstring(buffer);// byte[] mybyte = system.text.encoding.utf8.getbytes(msg);// //写入文件 using (filestream fswrite = new filestream(@"d:\2.txt, filemode.append))//处理完成再追加 { fswrite.write(mybyte, 0, mybyte.length); } } fsread.close(); } }
写入文件后期,还牵扯到数据的拼接与处理
个人感觉,数据如果要按照一定格式拼接,可以通过改变每次读取的位置,来处理。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。