0
    void  insert_into_stream(std::ostream& stream,  int number)
{
    int length = sizeof(int);
    char insert_buffer[sizeof(int)];
    memcpy(insert_buffer, &number, length);
    stream.write(insert_buffer, length);
}

int int_from_string(std::string string)
{
    int a; 
    std::istringstream(string)>>a;
    return a;
}

这段代码以前可以工作,我不记得我做了什么细微的改变,它不再工作了。当一个数字(例如 8001)进来时,我在最后一条语句之前进行调试,insert_buffer 包含“A”,所以很明显出了点问题,第二个函数没有检索到 8001。

注意 - 在将流发送到第二个函数之前,我确实将流转换为字符串。

第一个函数哪里错了?

- -编辑 - -

是的,我错了,第一个功能实际上是在做它应该做的,第二个是错的,有人可以解决这个问题吗?

4

2 回答 2

1

这两个函数在做完全不同的事情。

第一个函数是将整数的原始二进制表示写出到流中。

您刚刚复制了这些位,如果您要序列化为二进制文件,这是正确的做法。

要将其转换回来,您必须读取这 4 个字节,并将其转换为整数,就像您正在做相反的事情一样。

当然,当您检查字符时,它们将是整数位的单字节 ascii 表示。所以'A'是一个完全合理的东西,因为它是完全没有意义的。

然而,第二个函数是进行 ASCII 数字到整数的转换。即atoi。这对于您尝试执行的操作毫无意义,因为字符不是 ascii 数字,它们是二进制整数。

编辑编辑:你想要这样的东西,与你上面所做的相反。

int int_from_string(const char* number)
{
    int a; 
    memcpy(&a, number, sizeof(int));
    return a;
}
于 2013-07-16T13:53:35.323 回答
0

尝试使用

stream.write((const char*)&number, sizeof(number));

它要短得多,您还可以更改数字的类型,它会起作用(对于简单类型)。

于 2013-07-16T13:48:23.590 回答