Я использовал последовательность 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
, поставив завершающий ноль следующим образом:
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
, который смог записать непосредственно в массив символов, который вы разместили в стеке. Вы должны были вставить завершающий ноль вручную. Тем не менее, std::ends
не считается устаревшим, я думаю, потому что он все еще полезен, как в вышеупомянутых случаях.