shared_ptr& operator=( const shared_ptr& r ) noexcept;  |  (1) | |
 template< class Y > shared_ptr& operator=( const shared_ptr<Y>& r ) noexcept;  |  (1) | |
 shared_ptr& operator=( shared_ptr&& r ) noexcept;  |  (2) | |
 template< class Y > shared_ptr& operator=( shared_ptr<Y>&& r ) noexcept;  |  (2) | |
 template< class Y > shared_ptr& operator=( std::auto_ptr<Y>&& r );  |  (3) |  (deprecated in C++11)  (removed in C++17)  |  
 template< class Y, class Deleter > shared_ptr& operator=( std::unique_ptr<Y,Deleter>&& r );  |  (4) | 
Replaces the managed object with the one managed by r.
If *this already owns an object and it is the last shared_ptr owning it, and r is not the same as *this, the object is destroyed through the owned deleter.
r. If r manages no object, *this manages no object too. Equivalent to shared_ptr<T>(r).swap(*this).shared_ptr from r. After the assignment, *this contains a copy of the previous state of r, and r is empty. Equivalent to shared_ptr<T>(std::move(r)).swap(*this).r to *this. If r manages no object, *this manages no object too. After the assignment, *this contains the pointer previously held by r, and use_count()==1; also r is empty. Equivalent to shared_ptr<T>(r).swap(*this).r to *this. The deleter associated to r is stored for future deletion of the managed object. r manages no object after the call. Equivalent to shared_ptr<T>(std::move(r)).swap(*this).| r | - | another smart pointer to share the ownership to or acquire the ownership from | 
*this.
The implementation may meet the requirements without creating a temporary shared_ptr object.
|  replaces the managed object  (public member function)  | 
    © cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
    https://en.cppreference.com/w/cpp/memory/shared_ptr/operator%3D