std::experimental::unique_resource<R, D>::operator=
From cppreference.com
< cpp | experimental | unique resource
| unique_resource& operator=( unique_resource&& other ) noexcept(/*see below*/); |
(library fundamentals TS v3) | |
Move assignment operator. Replaces the managed resource and the deleter with other's.
Formally, let RS be the type of stored resource handle:
- First, calls reset() to dispose the currently owned resource, if any.
- Then assigns the stored resource handle and the deleter with other's.
std::moveis applied to the stored resource handle or the deleter of other if std::is_nothrow_move_assignable_v<RS> or std::is_nothrow_move_assignable_v<D> is true respectively. Assignment of the stored resource handle is executed first, unless std::is_nothrow_move_assignable_v<D> is false and std::is_nothrow_move_assignable_v<RS> is true. - Finally, sets *this to own the resource if and only if other owned it before assignment, and other not to own the resource.
If std::is_nothrow_move_assignable_v<RS> is true, RS shall satisfy the MoveAssignable requirements; otherwise RS shall satisfy the CopyAssignable requirements. If std::is_nothrow_move_assignable_v<D> is true, D shall satisfy the MoveAssignable requirements; otherwise D shall satisfy the CopyAssignable requirements. Failing to satisfy above requirements results in undefined behavior.
Parameters
| other | - | resource wrapper from which ownership will be transferred |
Return value
*this
Exceptions
Any exception thrown in copy-assignment.
noexcept specification:
noexcept(std::is_nothrow_move_assignable_v<RS> && std::is_nothrow_move_assignable_v<D>)
Notes
If a copy of a member throws an exception, this mechanism leaves other intact and *this in the released state.
Example
| This section is incomplete Reason: no example |
See also
| disposes or replaces the managed resource (public member function) | |
assigns the unique_ptr (public member function of std::unique_ptr<T,Deleter>) |