幾分鐘搞懂c#之FileStream對象讀寫大文件(推薦)
還是一樣,我先上代碼,但是為了你們測試結果和我一樣,必須先有準備工作,否則會找不到目錄或者文件就沒有效果;

既然是讀取大文件,那么這個文本必須存在
現(xiàn)在來看目標目錄

其實這里的文本文件可以刪除,因為我們寫入文本數(shù)據(jù)的時候的模式是當沒有找到文件就創(chuàng)建新的。
下面上的上代碼
“`
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)) //打開文件,不能創(chuàng)建新的
{
//構建寫文件流對象
using (FileStream fsWrite = new FileStream(_StrTagrgetPath,FileMode.Create)) //沒有找到就創(chuàng)建
{
//開辟臨時緩存內存
byte[] byteArrayRead = new byte[1024 * 1024]; // 1字節(jié)*1024 = 1k 1k*1024 = 1M內存
//通過死緩存去讀文本中的內容
while(true)
{
//readCount 這個是保存真正讀取到的字節(jié)數(shù)
int readCount = fsRead.Read(byteArrayRead, 0, byteArrayRead.Length);
//開始寫入讀取到緩存內存中的數(shù)據(jù)到目標文本文件中
fsWrite.Write(byteArrayRead, 0, readCount);
//既然是死循環(huán) 那么什么時候我們停止讀取文本內容 我們知道文本最后一行的大小肯定是小于緩存內存大小的
if(readCount < byteArrayRead.Length)
{
break; //結束循環(huán)
}
}
}
}
}
else
{
Console.WriteLine("源路徑或者目標路徑不存在。");
}
}
static void Main(string[] args)
{
Program p = new Program();
p.Test();
}
}
一定要上機測試,具體每行代碼解釋的很清楚,就不多解釋了。
以上所述是小編給大家介紹的c#之FileStream對象讀寫大文件詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
Silverlight文件上傳下載實現(xiàn)方法(下載保存)
這篇文章主要介紹了Silverlight文件上傳下載實現(xiàn)方法(下載保存) ,需要的朋友可以參考下2015-11-11
c#中directory 和directoryinfo的使用小結
當使用C#處理目錄時,可以使用?System.IO?命名空間中的?Directory?和?DirectoryInfo?類來執(zhí)行各種目錄操作,本文主要介紹了c#中directory 和directoryinfo的使用小結,感興趣的可以了解一下2024-02-02
C#使用晚綁定來實現(xiàn)壓縮Access數(shù)據(jù)庫的方法
這篇文章主要介紹了C#使用晚綁定來實現(xiàn)壓縮Access數(shù)據(jù)庫的方法,項目開發(fā)中有一定的實用價值,需要的朋友可以參考下2014-08-08
c#linq里的Skip和Take實現(xiàn)分頁或遍歷
LINQ的優(yōu)勢在于它提供了一種直觀、類型安全的方式來操作各種類型的數(shù)據(jù),查詢常需要獲取一部分數(shù)據(jù),為了實現(xiàn)這一功能,LINQ提供了Take?和Skip運算符,Take運算符用于從一個序列中返回指定個數(shù)的元素,Skip運算符用于從一個序列中跳過指定個數(shù)的元素2024-01-01

