Scroll to navigation

std::basic_stringbuf::operator=(3) C++ Standard Libary std::basic_stringbuf::operator=(3)

NAME

std::basic_stringbuf::operator= - std::basic_stringbuf::operator=

Synopsis


std::basic_stringbuf& operator=( std::basic_stringbuf&& rhs ); (1) (since C++11)
std::basic_stringbuf& operator=( const std::basic_stringbuf& rhs ) (2)
= delete;


1) Move assignment operator: Moves the contents of rhs into *this. After the move,
*this has the associated string, the open mode, the locale, and all other state
formerly held by rhs. The six pointers of std::basic_streambuf in *this are
guaranteed to be different from the corresponding pointers in the moved-from rhs
unless null.
2) The copy assignment operator is deleted; basic_stringbuf is not CopyAssignable.

Parameters


rhs - another basic_stringbuf that will be moved from

Return value


*this

Example

// Run this code


#include <iostream>
#include <sstream>
#include <string>


int main()
{
std::istringstream one("one");
std::ostringstream two("two");


std::cout << "Before move, one = \"" << one.str() << '"'
<< " two = \"" << two.str() << "\"\n";


*one.rdbuf() = std::move(*two.rdbuf());


std::cout << "After move, one = \"" << one.str() << '"'
<< " two = \"" << two.str() << "\"\n";
}

Output:


Before move, one = "one" two = "two"
After move, one = "two" two = ""

See also


constructor constructs a basic_stringbuf object
(public member function)

2024.06.10 http://cppreference.com