String Streams

Clearing a String Stream

How do I clear a string stream in C++?

Abstract art representing computer programming

Clearing a string stream in C++ involves both resetting the content and clearing the state flags. This ensures that the stream is ready for new operations without retaining any old data or error states.

Resetting the Content

To clear the content of a string stream, you can use the str() method with an empty string. This sets the internal buffer to an empty state:

std::ostringstream Stream;
Stream.str("");

Clearing the State Flags

After resetting the content, it's also important to clear the state flags to ensure the stream is in a good state for further use. Use the clear() method for this purpose:

Stream.clear();

Combined Example

Here's a complete example demonstrating how to clear a string stream properly:

#include <iostream>
#include <sstream>

int main() {
  std::ostringstream Stream;
  Stream << "Some initial content";
  std::cout << "Before clearing: "
    << Stream.str() << "\n";

  // Clear the stream
  Stream.str("");  
  Stream.clear();  

  Stream << "New content after clearing";
  std::cout << "After clearing: "
    << Stream.str() << "\n";
}
Before clearing: Some initial content
After clearing: New content after clearing

Why Clear the Stream?

Clearing the stream ensures that previous content and error states do not interfere with new operations. This is particularly useful when reusing a string stream in a loop or a function that processes multiple pieces of data.

Practical Use Case

Consider a function that processes multiple data items and uses a string stream to format the output. Clearing the stream between iterations ensures that each piece of data is handled independently:

#include <iostream>
#include <sstream>
#include <vector>

void ProcessData(
  const std::vector<std::string>& data
) {
  std::ostringstream Stream;
  for (const auto& item : data) {
    Stream << "Processing: " << item;
    std::cout << Stream.str() << "\n";

    // Clear the stream for the next item
    Stream.str("");
    Stream.clear();
  }
}

int main() {
  std::vector<std::string> data{
    "Item1", "Item2", "Item3"
  };
  ProcessData(data);
}
Processing: Item1
Processing: Item2
Processing: Item3

Summary

  • Reset Content: Use str("") to clear the internal buffer.
  • Clear State Flags: Use clear() to reset the stream state.
  • Practical Application: Ensures the stream is ready for new operations, especially useful in loops and repetitive tasks.

Clearing a string stream is essential for maintaining clean and efficient code, particularly when the same stream object is reused multiple times.

Answers to questions are automatically generated and may not have been reviewed.

A computer programmer
Part of the course:

Professional C++

Comprehensive course covering advanced concepts, and how to use them on large-scale projects.

Free, unlimited access

This course includes:

  • 125 Lessons
  • 550+ Code Samples
  • 96% Positive Reviews
  • Regularly Updated
  • Help and FAQ
Free, Unlimited Access

Professional C++

Comprehensive course covering advanced concepts, and how to use them on large-scale projects.

Screenshot from Warhammer: Total War
Screenshot from Tomb Raider
Screenshot from Jedi: Fallen Order
Contact|Privacy Policy|Terms of Use
Copyright © 2025 - All Rights Reserved