from example c++ stl reset ostringstream

c++ - example - get string from ostringstream



Cómo reutilizar un ostringstream? (4)

He usado una secuencia de clear y str en el pasado:

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

Lo cual ha hecho la cosa tanto para las cadenas de entrada como para las de salida. Alternativamente, puede borrar manualmente, luego buscar la secuencia apropiada para comenzar:

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

Esto evitará algunas reasignaciones hechas por str sobrescribiendo lo que está en el búfer de salida actualmente. Los resultados son así:

std::ostringstream s; s << "hello"; s.seekp(0); s << "b"; assert(s.str() == "bello");

Si desea usar la cadena para las funciones c, puede usar std::ends , poniendo un nulo de terminación como este:

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 es una reliquia de std::strstream desuso, que fue capaz de escribir directamente en una matriz char que asignó en la pila. Debes insertar un nulo de terminación manualmente. Sin embargo, std::ends no está en desuso, creo que porque sigue siendo útil como en los casos anteriores.

Me gustaría borrar y reutilizar un ostringstream (y el buffer subyacente) para que mi aplicación no tenga que hacer tantas asignaciones. ¿Cómo reinicio el objeto a su estado inicial?


Parece ser que la ostr.str("") hace el truco.


Si va a borrar el búfer de una manera que haga que se borre antes de usarlo por primera vez, deberá agregar algo al búfer primero con 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 } };


Tu no Utilice dos secuencias con nombres diferentes para mayor claridad y deje que el compilador optimizador descubra que puede reutilizar el anterior.