Как повторно использовать ostringstream?
Я хотел бы очистить и повторно использовать ostringstream (и базовый буфер), чтобы мое приложение не должно было делать столько выделений. Как сбросить объект в исходное состояние?
4 ответа:
я использовал последовательность 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
, который смог записать непосредственно в массив символов, выделенный в стеке. Вы должны были вставить завершающий null вручную. Однако,std::ends
не является устаревшим, я думаю, потому что это все еще полезно, как в приведенных выше случаях.
Если вы собираетесь очистить буфер таким образом, что он будет очищен до его первого использования, вам нужно будет сначала добавить что-то в буфер w/ 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 } };