如何重用ostringstream?

我想清除和重用一个ostringstream(和底层的缓冲区),这样我的应用程序就不必做很多的分配。 如何将对象重置为初始状态?

过去我已经使用了一系列清晰的,

// clear, because eof or other bits may be still set. s.clear(); s.str(""); 

这对于input和输出stringstream都是有效的。 或者,你可以手动清除,然后寻找适当的序列开始:

 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"); 

如果你想使用string作为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是不赞成使用的std::strstream的残余,它能够直接写入你在堆栈中分配的char数组。 您必须手动插入终止的空值。 然而, std::ends不被弃用,我想这是因为它仍然是有用的在上面的情况。

似乎是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 } }; 

你没有。 为了清楚起见,使用两个不同名称的stream,让优化编译器找出它可以重用旧的stream。