Kaedah perbandingan fail yang cekap .NET
Apabila membandingkan dua fail, kelajuan selalunya menjadi perkara utama. Kaedah tradisional membaca fail bait demi bait sangat memakan masa untuk fail besar. Artikel ini meneroka cara untuk melakukan perbandingan fail yang lebih pantas dalam .NET, termasuk perbandingan semak dan perbandingan tatasusunan bait tersuai.
Perbandingan Checksum: Penyelesaian Kemungkinan?
Perbandingan checksum (seperti Cyclic Redundancy Check (CRC)) menjana cap jari yang unik untuk setiap fail. Membandingkan cap jari ini adalah lebih pantas daripada membandingkan keseluruhan bait fail demi bait. Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa jumlah semak mungkin menghasilkan positif palsu, jadi semakan tambahan mungkin diperlukan untuk memastikan ketepatan.
Prestasi perbandingan checksum:
Walaupun perbandingan checksum lebih pantas daripada perbandingan bait demi bait dalam sesetengah kes, ia bukanlah penyelesaian yang terbaik. Ujian kami telah menunjukkan bahawa perbandingan sentiasa boleh diselesaikan dalam sub-saat menggunakan algoritma pencincangan MD5.
Sesuaikan perbandingan tatasusunan bait untuk mengoptimumkan prestasi:
Kami mencadangkan kaedah perbandingan tatasusunan bait tersuai yang berprestasi lebih baik daripada perbandingan bait demi bait. Kaedah ini membaca blok bait ke dalam tatasusunan dan membandingkan nilai tatasusunan sebagai integer. Keselarian ini mengurangkan overhed perbandingan bait individu.
Contoh kod untuk perbandingan tatasusunan bait:
<code class="language-csharp">const int BYTES_TO_READ = sizeof(Int64); static bool FilesAreEqual(FileInfo first, FileInfo second) { if (first.Length != second.Length) return false; if (string.Equals(first.FullName, second.FullName, StringComparison.OrdinalIgnoreCase)) return true; int iterations = (int)Math.Ceiling((double)first.Length / BYTES_TO_READ); using (FileStream fs1 = first.OpenRead()) using (FileStream fs2 = second.OpenRead()) { byte[] one = new byte[BYTES_TO_READ]; byte[] two = new byte[BYTES_TO_READ]; for (int i = 0; i < iterations; i++) { fs1.Read(one, 0, BYTES_TO_READ); fs2.Read(two, 0, BYTES_TO_READ); if (!one.SequenceEqual(two)) return false; } } return true; }</code>
Uji dan Bandingkan:
Dalam ujian kami, perbandingan tatasusunan bait tersuai menunjukkan prestasi hampir 3 kali lebih baik daripada perbandingan bait demi bait langsung. Walaupun kaedah cincang adalah lebih perlahan daripada tatasusunan bait, ia sentiasa boleh diselesaikan dalam masa 1 saat dalam ujian.
Dengan memilih kaedah perbandingan fail yang sesuai berdasarkan saiz fail dan keperluan ketepatan, pembangun boleh mencapai perbandingan fail yang pantas dan cekap dalam aplikasi .NET.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencapai Perbandingan Fail yang Cekap dalam .NET?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!