I have two binary files and I want to compare them Byte by Byte. I came up with the following code to do so:
int CompareFiles(char *pFname1, char *pFname2)
{
fread(&tmp1, sizeof(char), 1, pFile1+i);
fread(&tmp2, sizeof(char), 1, pFile2+i);
is changing the file handle for each iteration of the loop. You should use
fread(&tmp1, 1, 1, pFile1);
fread(&tmp2, 1, 1, pFile2);
instead. Each call to fread
will advance the file handle's internal pointer to it's file content automatically.
Note that you also log differences in file content but fail to return an error to calling code during your for
loop.
If you want to return as soon as you encounter a difference, use
for (i=0;i<lSize1;i++) {
fread(&tmp1, 1, 1, pFile1);
fread(&tmp2, 1, 1, pFile2);
if (tmp1 != tmp2) {
printf("%x: tmp1 0x%x != tmp2 0x%x\n",i , tmp1, tmp2);
return ( ERROR ); // report error to caller
}
}
return ( OK );
If you want to log all differences (this will be potentially very time consuming), use
int err = OK;
for (i=0;i<lSize1;i++) {
fread(&tmp1, 1, 1, pFile1);
fread(&tmp2, 1, 1, pFile2);
if (tmp1 != tmp2) {
printf("%x: tmp1 0x%x != tmp2 0x%x\n",i , tmp1, tmp2);
err = ERROR; // report error to caller
}
}
return err;