幾分鐘搞懂c#之FileStream對象讀寫大文件(推薦)
更新時間:2019年04月30日 13:58:15 作者:牛掰是怎么形成的
這篇文章主要介紹了c#之FileStream對象讀寫大文件,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
還是一樣,我先上代碼,但是為了你們測試結(jié)果和我一樣,必須先有準備工作,否則會找不到目錄或者文件就沒有效果;

既然是讀取大文件,那么這個文本必須存在
現(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))
{
//構(gòu)造讀取文件流對象
using (FileStream fsRead = new FileStream(_StrSourcePath, FileMode.Open)) //打開文件,不能創(chuàng)建新的
{
//構(gòu)建寫文件流對象
using (FileStream fsWrite = new FileStream(_StrTagrgetPath,FileMode.Create)) //沒有找到就創(chuàng)建
{
//開辟臨時緩存內(nèi)存
byte[] byteArrayRead = new byte[1024 * 1024]; // 1字節(jié)*1024 = 1k 1k*1024 = 1M內(nèi)存
//通過死緩存去讀文本中的內(nèi)容
while(true)
{
//readCount 這個是保存真正讀取到的字節(jié)數(shù)
int readCount = fsRead.Read(byteArrayRead, 0, byteArrayRead.Length);
//開始寫入讀取到緩存內(nèi)存中的數(shù)據(jù)到目標文本文件中
fsWrite.Write(byteArrayRead, 0, readCount);
//既然是死循環(huán) 那么什么時候我們停止讀取文本內(nèi)容 我們知道文本最后一行的大小肯定是小于緩存內(nèi)存大小的
if(readCount < byteArrayRead.Length)
{
break; //結(jié)束循環(huán)
}
}
}
}
}
else
{
Console.WriteLine("源路徑或者目標路徑不存在。");
}
}
static void Main(string[] args)
{
Program p = new Program();
p.Test();
}
}
一定要上機測試,具體每行代碼解釋的很清楚,就不多解釋了。
以上所述是小編給大家介紹的c#之FileStream對象讀寫大文件詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
C# 通過同步和異步實現(xiàn)優(yōu)化做早餐的時間
本文以一個簡單的小例子—如何做一頓早餐及如何優(yōu)化做早餐的時間來讓大家具體了解一下同步和異步方法的區(qū)別,需要的朋友可以參考一下2021-12-12

