Ich habe schon mehrere Dinge ausprobiert,
std::stringstream m;
m.empty();
m.clear();
beide funktionieren nicht.
quelle
Ich habe schon mehrere Dinge ausprobiert,
std::stringstream m;
m.empty();
m.clear();
beide funktionieren nicht.
Für alle Standardbibliothekstypen ist die Mitgliedsfunktion empty()
eine Abfrage, kein Befehl, dh sie bedeutet "Sind Sie leer?" nicht "Bitte werfen Sie Ihren Inhalt weg".
Die clear()
Member-Funktion wird von geerbt ios
und zum Löschen des Fehlerstatus des Streams verwendet. Wenn beispielsweise für einen Dateistream der Fehlerstatus auf eofbit
(Dateiende) festgelegt ist, wird durch Aufrufen clear()
der Fehlerstatus auf goodbit
(kein Fehler) zurückgesetzt. .
Zum Löschen des Inhalts von a stringstream
verwenden Sie:
m.str("");
ist richtig, obwohl mit:
m.str(std::string());
ist technisch effizienter, da Sie das Aufrufen des erforderlichen std::string
Konstruktors vermeiden const char*
. Aber heutzutage sollte jeder Compiler in beiden Fällen den gleichen Code generieren können - also würde ich einfach alles verwenden, was besser lesbar ist.
Sie können den Fehlerstatus löschen und den Stringstream in einer Zeile leeren
Dadurch wird m effektiv auf einen standardmäßig erstellten Zustand zurückgesetzt
quelle
scheint zu funktionieren.
quelle
Dies sollte unabhängig vom Compiler der zuverlässigste Weg sein:
quelle
mm.clear(); mm.str("");
hat es den Trick getan. (kein C ++ 11, sonst wäre Swap besser).swap
besser als Umzugszuweisung ?Ich bin immer dabei:
quelle
stringstream?
meine 2 Cent:
Dies schien für mich in xcode und dev-c ++ zu funktionieren. Ich hatte ein Programm in Form eines Menüs, das, wenn es gemäß der Anforderung eines Benutzers iterativ ausgeführt wird, eine Stringstream-Variable ausfüllt, die beim ersten Mal in Ordnung ist run, würde aber den Stringstream nicht löschen, wenn der Benutzer das nächste Mal denselben Code ausführt. Die beiden folgenden Codezeilen haben die Stringstream-Variable jedoch jedes Mal gelöscht, bevor die String-Variable aufgefüllt wurde. (2 Stunden Versuch und Irrtum und Google-Suche), übrigens, jede Zeile für sich zu verwenden, würde den Trick nicht tun.
quelle
Es ist ein konzeptionelles Problem.
Stringstream ist ein Stream, daher sind seine Iteratoren vorwärts und können nicht zurückkehren. In einem Ausgabe-Stringstream benötigen Sie ein Flush (), um ihn wie in jedem anderen Ausgabestream neu zu initialisieren.
quelle
Diese verwerfen die Daten im Stringstream in gnu c ++ nicht
Folgendes leert den Stringstream für mich:
quelle