La méthode la plus lente possible consiste à comparer deux fichiers octet par octet. La méthode la plus rapide que j'ai pu trouver est une comparaison similaire, mais au lieu d'un octet à la fois, vous utiliseriez un tableau d'octets de taille Int64, puis vous compareriez les nombres résultants.
Voici ce que j'ai trouvé :
const int BYTES_TO_READ = sizeof(Int64);
static bool FilesAreEqual(FileInfo first, FileInfo second)
{
if (first.Length != second.Length)
return false;
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 (BitConverter.ToInt64(one,0) != BitConverter.ToInt64(two,0))
return false;
}
}
return true;
}
Lors de mes tests, j'ai pu constater que cette méthode était plus performante qu'un simple scénario ReadByte() dans un rapport de presque 3:1. Sur une moyenne de 1000 exécutions, j'ai obtenu cette méthode à 1063 ms, et la méthode ci-dessous (comparaison directe octet par octet) à 3031 ms. Le hachage est toujours revenu à moins d'une seconde avec une moyenne de 865 ms. Ces tests ont été effectués avec un fichier vidéo d'environ 100 Mo.
Voici les méthodes ReadByte et hashing que j'ai utilisées, à titre de comparaison :
static bool FilesAreEqual_OneByte(FileInfo first, FileInfo second)
{
if (first.Length != second.Length)
return false;
using (FileStream fs1 = first.OpenRead())
using (FileStream fs2 = second.OpenRead())
{
for (int i = 0; i < first.Length; i++)
{
if (fs1.ReadByte() != fs2.ReadByte())
return false;
}
}
return true;
}
static bool FilesAreEqual_Hash(FileInfo first, FileInfo second)
{
byte[] firstHash = MD5.Create().ComputeHash(first.OpenRead());
byte[] secondHash = MD5.Create().ComputeHash(second.OpenRead());
for (int i=0; i<firstHash.Length; i++)
{
if (firstHash[i] != secondHash[i])
return false;
}
return true;
}
0 votes
Dupe : stackoverflow.com/questions/211008/c-file-management