Answers:
过去,我使用了一系列clear和str:
// clear, because eof or other bits may be still set.
s.clear();
s.str("");
这样做对输入和输出字符串流都起作用。或者,您可以手动清除,然后从头开始寻找适当的顺序:
s.clear();
s.seekp(0); // for outputs: seek put ptr to start
s.seekg(0); // for inputs: seek get ptr to start
这将str
通过覆盖当前输出缓冲区中的内容来防止某些重新分配。结果是这样的:
std::ostringstream s;
s << "hello";
s.seekp(0);
s << "b";
assert(s.str() == "bello");
如果要将字符串用于c函数,则可以使用std::ends
,放置一个终止null,如下所示:
std::ostringstream s;
s << "hello";
s.seekp(0);
s << "b" << std::ends;
assert(s.str().size() == 5 && std::strlen(s.str().data()) == 1);
std::ends
是deprecated的遗留物std::strstream
,它可以直接写入您在堆栈上分配的char数组。您必须手动插入终止null。但是,std::ends
我不认为它已被弃用,因为它在上述情况下仍然很有用。
s.str("");
。auto str = s.str(); auto cstr = str.c_str(); file << cstr; s.clear(); s.seekp(0); s << ends;
boost::any a = 1; std::ostringstream buffer; buffer << a << std::ends; EXPECT_EQ( buffer.str(), "any<(int)1>" );
TestUtilsTest.cpp:27: Failure Expected: buffer.str() Which is: "any<(int)1>\0" To be equal to: "any<(int)1>"
,如果我使用不同长度的字符串重复使用,我会被遗忘
s.seekp(0); s << std::ends; s.seekp(0);
似乎是ostr.str("")
电话能解决问题。
如果要以某种方式清除缓冲区,以使其在首次使用前就被清除,则需要先使用MSVC向缓冲区中添加一些内容。
struct Foo {
std::ostringstream d_str;
Foo() {
d_str << std::ends; // Add this
}
void StrFunc(const char *);
template<class T>
inline void StrIt(const T &value) {
d_str.clear();
d_str.seekp(0); // Or else you'll get an error with this seek
d_str << value << std::ends;
StrFunc(d_str.str().c_str()); // And your string will be empty
}
};
你不知道 为了清楚起见,使用两个不同名称的流,让优化编译器确定它可以重用旧的流。
ostringstream
(基于读取的数据),然后必须ostringstream
不时写入某个地方(例如,在读取某些字符序列之后)内置的字符串,然后开始建立一个新的字符串。