std::basic_stringbuf<CharT,Traits,Allocator>::swap
From cppreference.com
                    
                                        
                    < cpp | io | basic stringbuf
                    
                                                            
                    | void swap( basic_stringbuf& rhs ); | (since C++11) (until C++20) | |
| void swap( basic_stringbuf& rhs ) noexcept(/* see below */); | (since C++20) | |
Swaps the state and the contents of *this and rhs.
| The behavior is undefined if  | (since C++11) | 
Parameters
| rhs | - | another basic_stringbuf | 
Return value
(none)
Exceptions
| (none) | (since C++11) (until C++20) | 
| noexcept specification:  
 noexcept(std::allocator_traits<Allocator>::propagate_on_container_swap::value || std::allocator_traits<Allocator>::is_always_equal::value) | (since C++20) | 
Notes
This function is called automatically when swapping std::stringstream objects, it is rarely necessary to call it directly.
Example
Run this code
#include <sstream> #include <string> #include <iostream> int main() { std::istringstream one("one"); std::ostringstream two("two"); std::cout << "Before swap, one = \"" << one.str() << '"' << " two = \"" << two.str() << "\"\n"; *one.rdbuf()->swap(*two.rdbuf()); std::cout << "Before swap, one = \"" << one.str() << '"' << " two = \"" << two.str() << "\"\n"; }
Output:
Before swap, one = "one" two = "two" Before swap, one = "two" two = "one"
See also
| constructs a basic_stringbuf object (public member function) | |
| (C++11) | swaps two string streams (public member function of std::basic_stringstream<CharT,Traits,Allocator>) |