0

我的问题是在文件描述符上使用 ifstream read 和 fread 似乎不会产生相同的结果。

我打开一个文件并在 ios::binary 模式下使用 ifstream open/read 读取它的输入。然后我把这个缓冲区写到一个文件中。出1。

接下来,我打开同一个文件,使用 FILE* 文件描述符和 fread 读取其输入。然后我把这个缓冲区写到另一个文件out2。

当我将 out1 与 out2 进行比较时,它们不匹配。使用 FILE* 的 out2 似乎在接近尾声时停止读取。

更令人担忧的是,两个缓冲区都与输入文件不匹配。ifstream::read 方法似乎正在修改行尾字符,即使我将输入文件打开为 ios::binary。

fread 方法似乎返回的值小于长度(199),即使它读取的字符比这要多得多,因为我可以看到读取的缓冲区。这与 seekg 命令确定的长度不匹配。

我很困惑,任何帮助将不胜感激。附上代码。

谢谢!-朱利安

   ifstream read_file;
   read_file.open("V:\\temp\\compressiontest\\out\\test_20224-5120_256x256.jpg", ios::binary);

   read_file.seekg(0, ios::end);
   unsigned long length = read_file.tellg();
   cout << "Length: " << length << endl;
   read_file.seekg(0, ios::beg);

   unsigned char* buffer = new unsigned char[length];
   unsigned char* buf = new unsigned char[length];
   for(int i = 0; i < length; i++)
   {
      buffer[i] = 0;
      buf[i] = 0;
   }

   if(read_file.is_open())
   {
      read_file.read((char*)buffer, length);
   }
   else
   {
      cout << "not open" << endl;
   }

   read_file.close();

   FILE* read_file_1 = NULL;
   read_file_1 = fopen("V:\\temp\\compressiontest\\out\\test_20224-5120_256x256.jpg", "r");
   size_t read_len = fread(buf, 1, length, read_file_1);
   fclose(read_file_1);

   if(read_len != length)
      cout << "read len != length" << " read_len: " << read_len << " length: " << length << endl;

   int consistent = 0;
   int inconsistent = 0;
   for(int i = 0; i < length; i++)
   {
      if(buf[i] != buffer[i])
         inconsistent++;
      else
         consistent++;
   }

   cout << "inconsistent:" << inconsistent << endl;
   cout << "consistent:" << consistent << endl;

   FILE* file1;
   file1 = fopen("V:\\temp\\compressiontest\\out1.jpg", "w"); 
   fwrite((void*) buffer, 1, length, file1);
   fclose(file1);

   FILE* file2;
   file2 = fopen("V:\\temp\\compressiontest\\out2.jpg", "w"); 
   fwrite((void*) buf, 1, length, file2);
   fclose(file2);

   return 0;
4

1 回答 1

4

您正在调用fopen()来读取使用mode r而不是mode rb和写入使用mode w而不是mode wb,这在 Windows(默认)上意味着您正在使用文本翻译进行读写,而不是在二进制模式下。

于 2012-04-25T20:42:03.620 回答