【问题标题】:C++ ofstream doesn't write expected numbers into fileC ++ ofstream不会将预期数字写入文件
【发布时间】:2014-03-22 02:08:53
【问题描述】:

美好的一天, 我正在开发一个程序,该程序读入一个二进制文件(给出了读入的函数并且可以工作),然后将修改后的信息写回到另一个二进制文件中。 (我在两种格式之间进行更改。)如果我在之前(或之后)使用 std::cout 将数字发送到控制台,我使用 ofstream 将它们写入文件。我得到了我预期的数字,但如果我知道通过

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

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

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 应该写入文件中

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() 检查了输出流,还检查了文件是否打开。我也可以写入文件。并且 write 和

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

outs.close();

我也有同样的问题,数字错误。我注意到数字 0 对应于 0,但数字 1 转换为 16777216 为无符号 int 数字。

希望你能帮帮我,我不知道出了什么问题。

【问题讨论】:

  • 没有一个写入,我想要写入文件的内容... 您想要写入文件的内容是什么?可能是文本格式?
  • 不,这是一个数字列表,但它们之间没有任何分隔符。
  • 二进制格式呢? (注意您的cout &lt;&lt; ... 输出数字的文本字符翻译!!)
  • 我有 80% 的把握,它应该是二进制格式,但它也会产生错误的数字。 (在 ofstream 的开头有或没有 std::ios::binary)
  • 由于您没有显示任何代码,您将如何再次读取记录以及您希望读取的内容,因此很难判断出了什么问题。

标签: c++ ofstream


【解决方案1】:

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

通常,当您使用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&lt;&lt; 通常用于将数据写入文本。它在空间和速度方面效率较低,但具有人类可读的优势。将数据作为文本写入就像将其打印到屏幕一样简单,例如

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

【讨论】:

  • 我试过了,但它说某种内部编译器错误:in extract_insn
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2016-09-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-04-27
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多