幾分鐘搞懂c#之FileStream對象讀寫大文件(推薦)
更新時間:2019年04月30日 13:58:15 作者:牛掰是怎么形成的
這篇文章主要介紹了c#之FileStream對象讀寫大文件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
還是一樣,我先上代碼,但是為了你們測試結(jié)果和我一樣,必須先有準(zhǔn)備工作,否則會找不到目錄或者文件就沒有效果;
既然是讀取大文件,那么這個文本必須存在
現(xiàn)在來看目標(biāo)目錄
其實這里的文本文件可以刪除,因為我們寫入文本數(shù)據(jù)的時候的模式是當(dāng)沒有找到文件就創(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”; //目標(biāo)文件目錄
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ù)到目標(biāo)文本文件中 fsWrite.Write(byteArrayRead, 0, readCount); //既然是死循環(huán) 那么什么時候我們停止讀取文本內(nèi)容 我們知道文本最后一行的大小肯定是小于緩存內(nèi)存大小的 if(readCount < byteArrayRead.Length) { break; //結(jié)束循環(huán) } } } } } else { Console.WriteLine("源路徑或者目標(biāo)路徑不存在。"); } } static void Main(string[] args) { Program p = new Program(); p.Test(); } }
一定要上機(jī)測試,具體每行代碼解釋的很清楚,就不多解釋了。
以上所述是小編給大家介紹的c#之FileStream對象讀寫大文件詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
C# 通過同步和異步實現(xiàn)優(yōu)化做早餐的時間
本文以一個簡單的小例子—如何做一頓早餐及如何優(yōu)化做早餐的時間來讓大家具體了解一下同步和異步方法的區(qū)別,需要的朋友可以參考一下2021-12-12