Namespaces
Variants
Views
Actions

std::weak_ptr<T>::operator=

From cppreference.com
< cpp‎ | memory‎ | weak ptr
 
 
Utilities library
General utilities
Relational operators (deprecated in C++20)
 
Dynamic memory management
Uninitialized memory algorithms
Constrained uninitialized memory algorithms
Allocators
Garbage collection support
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)



 
 
weak_ptr& operator=( const weak_ptr& r ) noexcept;
(1) (since C++11)
template< class Y >
weak_ptr& operator=( const weak_ptr<Y>& r ) noexcept;
(2) (since C++11)
template< class Y >
weak_ptr& operator=( const shared_ptr<Y>& r ) noexcept;
(3) (since C++11)
weak_ptr& operator=( weak_ptr&& r ) noexcept;
(4) (since C++11)
template< class Y >
weak_ptr& operator=( weak_ptr<Y>&& r ) noexcept;
(5) (since C++11)

Replaces the managed object with the one managed by r. The object is shared with r. If r manages no object, *this manages no object too.

1-3) Equivalent to std::weak_ptr<T>(r).swap(*this).
4,5) Equivalent to std::weak_ptr<T>(std::move(r)).swap(*this).

Contents

[edit] Parameters

r - smart pointer to share an object with

[edit] Return value

*this

[edit] Notes

The implementation may meet the requirements without creating a temporary weak_ptr object.

[edit] Defect reports

The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

DR Applied to Behavior as published Correct behavior
LWG 2315 C++11 move semantic was not enabled for weak_ptr enabled

[edit] See also

creates a new weak_ptr
(public member function) [edit]
swaps the managed objects
(public member function) [edit]