我想清除并重用一个 ostringstream (和底层缓冲区),这样我的应用程序就不必做太多的分配。如何将对象重置为其初始状态?
twk
问问题
57141 次
4 回答
162
我过去使用过一系列 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 数组。您必须手动插入终止空值。但是,std::ends
我认为它并没有被弃用,因为它在上述情况下仍然有用。
于 2009-03-08T21:08:38.750 回答
6
似乎这个ostr.str("")
电话可以解决问题。
于 2009-03-08T21:01:43.150 回答
2
如果您要清除缓冲区以使其在第一次使用之前被清除,您需要首先使用 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
}
};
于 2011-11-03T00:31:56.380 回答
-2
你没有。为了清楚起见,使用两个不同命名的流,并让优化编译器确定它可以重用旧的流。
于 2009-03-08T21:04:01.680 回答