即每次復制文件的一小段,以節省總內存開銷。當然,本機復制也可以采用.NET內部的System.IO.File.Copy方法。
本文轉載:http://www.cnblogs.com/wolf-sun/p/3345392.html
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

