ifstream读取和fread不返回相同的数据,C ++

时间:2012-04-25 20:33:45

标签: c++ ifstream fread

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

我在ios :: binary模式下使用ifstream open / read打开一个文件并读取其输入。然后我将此缓冲区写入文件。 OUT1。

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

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

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

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

我很困惑,任何帮助都会受到赞赏。代码附后。

谢谢! -Julian

   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;

1 个答案:

答案 0 :(得分:4)

您使用mode r代替mode rb呼叫fopen()以及使用mode w而不是mode wb进行写入,这是在Windows上(默认)意味着您既可以阅读也可以使用文本翻译,而不是二进制模式。