1

我有一个奇怪的错误:我想将 ostringstream 的内容复制到无符号字符的向量中:

vector< uint8_t > buffer;
ostringstream os;
os << num1 << char1 << num2 << char2;

// 1. this will crash
buffer.insert( buffer.end(), os.str().begin(), os.str().end() );

// 2. this also crash
copy( os.str().begin(), os.str().end(), back_inserter( buffer );

string str = os.str();

// 4. this work 
buffer.insert( buffer.end(), str().begin(), str().end() );

// 5. this also works
copy( str().begin(), tr().end(), back_inserter( buffer );

我不明白为什么 1 和 2 在 Visual Studio 2010 上崩溃。

有人有什么建议吗?

编辑

解决方案是:

vector< uint8_t > buffer;
ostringstream os;
os << num1 << char1 << num2 << char2;

const string& str = os.str();

// 4. this work 
buffer.insert( buffer.end(), str().begin(), str().end() );
4

2 回答 2

2
os.str().begin()

返回一个新的临时字符串,其内容为os. 您将迭代器带到它的开头。

os.str().end()

返回另一个临时字符串,其内容为os. 您将迭代器带到它的末尾。

这两个迭代器无效,因为临时字符串现在超出了范围。此外,迭代器也不属于同一个序列(此处为字符串)。

你正在做的几乎甚至不考虑悬空迭代器)相当于

string str1 = os.str();
string str2 = os.str();

buffer.insert( buffer.end(), str1.begin(), str2.end() );
于 2013-05-17T20:19:48.283 回答
2

ostringstream::str()返回底层缓冲区的副本

在您的案例 1 和 2 中,您调用str()了两次(一次 forbegin()和一次 for end()),因此每个生成的迭代器都与缓冲区的不同副本相关。此外,这些字符串是临时的,因此它们会立即超出范围,从而使迭代器“悬空”。

于 2013-05-17T20:19:55.843 回答