美好的一天, 我正在开发一个程序,它读入一个二进制文件(用于读入的函数已给出并起作用),然后将修改后的信息写回到另一个二进制文件中。 (我在两种格式之间切换。)如果我在之前(或之后)使用 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/