几分钟搞懂c#之FileStream对象读写大文件(推荐)
程序员文章站
2023-11-01 09:12:58
还是一样,我先上代码,但是为了你们测试结果和我一样,必须先有准备工作,否则会找不到目录或者文件就没有效果;
既然是读取大文件,那么这个文本必须存在
现在来看目标目录...
还是一样,我先上代码,但是为了你们测试结果和我一样,必须先有准备工作,否则会找不到目录或者文件就没有效果;
既然是读取大文件,那么这个文本必须存在
现在来看目标目录
其实这里的文本文件可以删除,因为我们写入文本数据的时候的模式是当没有找到文件就创建新的。
下面上的上代码
“` using system; using system.collections.generic; using system.io; using system.reflection; using system.text; namespace io目录管理 { class program { private string _strsourcepath = @”e:\testdir\test\1.txt”; //源文件目录 private string _strtagrgetpath = @”f:\testdir\test\1.txt”; //目标文件目录
public void test() { //路径合法性判断 if(file.exists(_strsourcepath)) { //构造读取文件流对象 using (filestream fsread = new filestream(_strsourcepath, filemode.open)) //打开文件,不能创建新的 { //构建写文件流对象 using (filestream fswrite = new filestream(_strtagrgetpath,filemode.create)) //没有找到就创建 { //开辟临时缓存内存 byte[] bytearrayread = new byte[1024 * 1024]; // 1字节*1024 = 1k 1k*1024 = 1m内存 //通过死缓存去读文本中的内容 while(true) { //readcount 这个是保存真正读取到的字节数 int readcount = fsread.read(bytearrayread, 0, bytearrayread.length); //开始写入读取到缓存内存中的数据到目标文本文件中 fswrite.write(bytearrayread, 0, readcount); //既然是死循环 那么什么时候我们停止读取文本内容 我们知道文本最后一行的大小肯定是小于缓存内存大小的 if(readcount < bytearrayread.length) { break; //结束循环 } } } } } else { console.writeline("源路径或者目标路径不存在。"); } } static void main(string[] args) { program p = new program(); p.test(); } }
一定要上机测试,具体每行代码解释的很清楚,就不多解释了。
以上所述是小编给大家介绍的c#之filestream对象读写大文件详解整合,希望对大家有所帮助