C++ ofstream不会将预期的数字写入文件

标签 c++ ofstream

美好的一天, 我正在开发一个程序,它读入一个二进制文件(用于读入的函数已给出并起作用),然后将修改后的信息写回到另一个二进制文件中。 (我在两种格式之间切换。)如果我在之前(或之后)使用 std::cout 将数字发送到控制台,我使用 ofstream 将它们写入文件。我得到了我预期的数字,但如果我知道通过 << 或写入将它们输入 ofstream,然后查看文件的内容。 (存在从这种格式到原始格式的转换,我可以使用它。)然后我得到了 carbage。

struct Record {
  unsigned latch;
  float e, x, y, u, v, wt;}

我读入给定的文件并修改我读入的数字。(以下是主函数的一部分)。 header h 已定义,并且存在默认构造函数。 phsp.read 和 copy 给出并工作。 Reclen 对应于记录长度并确保 header 正确写入,因为它对于不同的输入可能不同。

std::ofstream outs;
outs.open(outfile, std::ios::out | std::ios::trunc);
Header h;
outs.write((char*) &h, reclen - 5);
for (int i=0; i<nMax; ++i){
   phsp.read(mp);
   copy(mp, ep);

Record rec;

修改数字并将它们放入 rec 中,rec 是一个结构体,上面已给出。 rec应该写入文件

outs<<rec.latch<<rec.e<<rec.x<<rec.y<<rec.u<<rec.v<<rec.wt;

outs.write((char*) &rec.latch, 4);outs.write((char*) &rec.e, 4);
outs.write((char*) &rec.x, 4); outs.write((char*) &rec.y, 4);
outs.write((char*) &rec.u, 4);outs.write((char*) &rec.v, 4);
outs.write((char*) &rec.wt, 4);

outs.write((char*) &rec, reclen);
}

其中没有一个写入我想要写入文件的内容,但如果我通过 std::cout 和控制台给出数字。我得到了预期的数字。

std::cout<<rec.latch<<' '<<rec.e<<' '<<rec.x<<' '<<rec.y<<' '<<rec.u<<' '<<rec.v<<
' '<<rec.wt<<'\n';

我还用 good() 检查了输出流,我还检查了文件是否打开。我也可以写入文件。此外,写入和 << 输出不提供相同的输出(可以预期)。我检查了 rec.i 的大小,它也对应于结构的大小。 最后,我再次更改标题,因为我现在有了新信息。

outs.seekp(5);
outs.write((char*) &h, reclen - 5);

outs.close();

我也有同样的问题,数字是假的。我注意到数字0对应0,但是数字1被转换为16777216为unsigned int number。

我希望你能帮助我,我不知道哪里出了问题。

最佳答案

您需要决定您的新文件格式应该使用二进制还是文本表示数据。

通常当您使用 ofstream::write() 时方法以二进制格式保存数据,这意味着它将表示为字节数组,其长度等于您正在编写的数据结构。因此,您将在文件中找到的不是数字,而是它的二进制表示形式,如果从文本中看,它通常看起来像垃圾。

您可以使用十六进制编辑器查看数字,或者您可以读回它,然后将其解释为您选择的类型。例如:

float number;
ifs.read(&number, sizeof(float); // read in the 4 bytes from the file into a float

这相当于做:

char* buffer = new char[sizeof(float)];
ifs.read(buffer, sizeof(float)];
float f = *(reinterpret_cast<float*>(buffer));

如果您在转换缓冲区之前打印出缓冲区的内容,您会看到与您在文件中看到的相同的垃圾。注意读写二进制数据需要ios::binary标志集。

operator<<通常用于将数据写入文本。它在空间和速度方面效率较低,但具有人类可读性的优势。将数据写入文本就像将其打印到屏幕上一样简单,例如

std::ofstream ofs;
ofs.open("file.txt");

float f = 1.337f;
ofs << "My float: " << f;
std::cout << "My float: " << f;

如果您在同一范围内使用上述代码,则文件中的内容不会与屏幕上显示的内容不同。

最后确保您的变量在使用之前已初始化,因为在您发布的代码中您没有这样做。例如。

Header h; // <-- this probably contains rubbish until initialized with some values
outs.write((char*) &h, reclen - 5); // <-- writes rubbish

关于C++ ofstream不会将预期的数字写入文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21919554/

相关文章:

c++ - 逐一组装类型的编译时列表 (C++)

c++ - arm-linux-androideabi STL编译报错

c++ - 显示环境变量 LD_LIBRARY_PATH

c++ - 将数字写入文件 - 奇怪的结果

c++ - 从/向二进制文件读取/写入十六进制字节

c++ - 如何在 Kurento OpenCV 模块中实现简单的 OpenCV 操作

c# - 在原始 Linux 套接字上接收来自任何协议(protocol)的数据包

c++ - ofstream 创建一个文件但不能写入它

c++ - 连接 const char* C++

c++ - 没有匹配函数调用 `std::basic_ofstream<char, std::char_traits<char>>::basic_ofstream(std::string&)'