如何重用ostringstream?

twk*_*twk 115 c++ stl reset ostringstream

我想清除并重用ostringstream(和底层缓冲区),以便我的应用程序不必执行尽可能多的分配.如何将对象重置为初始状态?

Joh*_*itb 151

我过去使用了一系列clear和str:

// clear, because eof or other bits may be still set. 
s.clear();
s.str("");
Run Code Online (Sandbox Code Playgroud)

这为输入和输出字符串流做了一件事.或者,您可以手动清除,然后寻找适当的序列到开头:

s.clear();
s.seekp(0); // for outputs: seek put ptr to start
s.seekg(0); // for inputs: seek get ptr to start
Run Code Online (Sandbox Code Playgroud)

这将阻止str通过覆盖当前输出缓冲区中的任何内容来完成一些重新分配.结果是这样的:

std::ostringstream s;
s << "hello";
s.seekp(0);
s << "b";
assert(s.str() == "bello");
Run Code Online (Sandbox Code Playgroud)

如果你想将字符串用于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);
Run Code Online (Sandbox Code Playgroud)

std::ends是不推荐使用的遗留物std::strstream,它能够直接写入您在堆栈上分配的char数组.您必须手动插入终止空值.但是,std::ends我没有弃用,我认为因为它仍然有用,如上述情况.


Die*_*lla 5

似乎这个ostr.str("")电话就是伎俩.

  • 值得指出的是,这不会重复使用ostringstream中的底层缓冲区 - 它只是分配一个新的缓冲区.因此,当您重用ostringstream对象时,您仍然在分配两个缓冲区.我不认为ostringstream是按照你想要的方式重用的. (8认同)
  • 它也没有清除状态,这是.clear()的作用.我同意,它真的不应该像这样使用.只需创建一个新的确定.只有你的个人资料,你会发现它是否有所作为. (2认同)