FileStream緩沖讀取和寫入可以提高性能。FileStream讀取文件的時候,是先講流放入內存,經Flash()方法后將內存中(緩沖中)的數據寫入文件。如果文件非常大,勢必消耗性能。特封裝在FileHelper中以備不時之需。參考文章:http://www.cnblogs.com/yangxiaohu1/archive/2008/06/20/1226949.html將該文章中提供的代碼少做修改,原文中進行了強制類型轉換,如果文件很大,比如4G,就會出現溢出的情況,復制的結果字節丟失嚴重,導致復制文件和源文件大小不一樣。這里修改的代碼如下:
1 public static class FileHelper 2 { 3 /// <summary> 4 /// 復制大文件 5 /// </summary> 6 /// <param name="fromPath">源文件的路徑</param> 7 /// <param name="toPath">文件保存的路徑</param> 8 /// <param name="eachReadLength">每次讀取的長度</param> 9 /// <returns>是否復制成功</returns> 10 public static bool CopyFile(string fromPath, string toPath, int eachReadLength) 11 { 12 //將源文件 讀取成文件流 13 FileStream fromFile = new FileStream(fromPath, FileMode.Open, FileAccess.Read); 14 //已追加的方式 寫入文件流 15 FileStream toFile = new FileStream(toPath, FileMode.Append, FileAccess.Write); 16 //實際讀取的文件長度 17 int toCopyLength = 0; 18 //如果每次讀取的長度小於 源文件的長度 分段讀取 19 if (eachReadLength < fromFile.Length) 20 { 21 byte[] buffer = new byte[eachReadLength]; 22 long copied = 0; 23 while (copied <= fromFile.Length - eachReadLength) 24 { 25 toCopyLength = fromFile.Read(buffer, 0, eachReadLength); 26 fromFile.Flush(); 27 toFile.Write(buffer, 0, eachReadLength); 28 toFile.Flush(); 29 //流的當前位置 30 toFile.Position = fromFile.Position; 31 copied += toCopyLength; 32 33 } 34 int left = (int)(fromFile.Length - copied); 35 toCopyLength = fromFile.Read(buffer, 0, left); 36 fromFile.Flush(); 37 toFile.Write(buffer, 0, left); 38 toFile.Flush(); 39 40 } 41 else 42 { 43 //如果每次拷貝的文件長度大於源文件的長度 則將實際文件長度直接拷貝 44 byte[] buffer = new byte[fromFile.Length]; 45 fromFile.Read(buffer, 0, buffer.Length); 46 fromFile.Flush(); 47 toFile.Write(buffer, 0, buffer.Length); 48 toFile.Flush(); 49 50 } 51 fromFile.Close(); 52 toFile.Close(); 53 return true; 54 } 55 }
測試代碼:
1 class Program 2 { 3 static void Main(string[] args) 4 { 5 6 Stopwatch watch = new Stopwatch(); 7 watch.Start(); 8 if (FileHelper.CopyFile(@"D:\安裝文件\新建文件夾\SQLSVRENT_2008R2_CHS.iso", @"F:\SQLSVRENT_2008R2_CHS.iso", 1024 * 1024 * 5)) 9 { 10 watch.Stop(); 11 Console.WriteLine("拷貝完成,耗時:" + watch.Elapsed.Seconds+"秒"); 12 13 } 14 Console.Read(); 15 } 16 17 }
結果:
MD5校驗結果:
文件: D:\安裝文件\新建文件夾\SQLSVRENT_2008R2_CHS.iso 大小: 4662884352 字節 修改時間: 2010年9月3日, 10:41:26 MD5: D2BC1D35D987CC6CB8401BFB0A1E1BC9 SHA1: 0EEFF017B21635DF33F33C47E31E911CB23390F7 CRC32: 55AC3C56 文件: F:\SQLSVRENT_2008R2_CHS.iso 大小: 4662884352 字節 修改時間: 2013年9月29日, 10:51:39 MD5: D2BC1D35D987CC6CB8401BFB0A1E1BC9 SHA1: 0EEFF017B21635DF33F33C47E31E911CB23390F7 CRC32: 55AC3C56