constexpr optional<T>& operator=(nullopt_t) noexcept;
constexpr optional<T>& operator=(const optional& rhs);
*this contains a value | *this does not contain a value | ||
rhs contains a value | assigns rhs.val to val | direct-non-list-initializes val with rhs.val | |
rhs does not contain a value | destroys the contained value by calling val.T::~T() | no effect |
constexpr optional& operator=(optional&& rhs) noexcept(see below);
*this contains a value | *this does not contain a value | ||
rhs contains a value | assigns std::move(rhs.val) to val | direct-non-list-initializes val with std::move(rhs.val) | |
rhs does not contain a value | destroys the contained value by calling val.T::~T() | no effect |
template<class U = remove_cv_t<T>> constexpr optional& operator=(U&& v);
template<class U> constexpr optional<T>& operator=(const optional<U>& rhs);
*this contains a value | *this does not contain a value | ||
rhs contains a value | assigns rhs.operator*() to val | direct-non-list-initializes val with rhs.operator*() | |
rhs does not contain a value | destroys the contained value by calling val.T::~T() | no effect |
template<class U> constexpr optional<T>& operator=(optional<U>&& rhs);
*this contains a value | *this does not contain a value | ||
rhs contains a value | assigns std::move(rhs).operator*() to val | direct-non-list-initializes val with std::move(rhs).operator*() | |
rhs does not contain a value | destroys the contained value by calling val.T::~T() | no effect |
template<class... Args> constexpr T& emplace(Args&&... args);
template<class U, class... Args> constexpr T& emplace(initializer_list<U> il, Args&&... args);