std::optional<T>:: operator=
|
optional
&
operator
=
(
std::
nullopt_t
)
noexcept
;
|
(1) |
(начиная с C++17)
(constexpr начиная с C++20) |
|
constexpr
optional
&
operator
=
(
const
optional
&
other
)
;
|
(2) | (начиная с C++17) |
|
constexpr
optional
&
operator
=
( optional && other ) noexcept ( /* см. ниже */ ) ; |
(3) | (начиная с C++17) |
|
template
<
class
U
>
optional & operator = ( const optional < U > & other ) ; |
(4) |
(начиная с C++17)
(constexpr начиная с C++20) |
|
template
<
class
U
>
optional & operator = ( optional < U > && other ) ; |
(5) |
(начиная с C++17)
(constexpr начиная с C++20) |
|
template
<
class
U
=
std::
remove_cv_t
<
T
>
>
optional & operator = ( U && value ) ; |
(6) |
(начиная с C++17)
(constexpr начиная с C++20) |
Заменяет содержимое * this содержимым other .
val
-
>
T
::
~T
(
)
для уничтожения содержащегося значения; в противном случае не оказывает эффекта.
*
this
не содержит значения после этого вызова.
| Эффект | * this содержит значение | * this не содержит значения |
|---|---|---|
| other содержит значение |
|
|
| other не содержит значения |
уничтожает содержащееся значение вызовом
val
-
>
T
::
~T
(
)
|
нет эффекта |
-
Следующие 12 значений являются
false
[1]
:
- std:: is_constructible_v < T, std:: optional < U > & >
- std:: is_constructible_v < T, const std:: optional < U > & >
- std:: is_constructible_v < T, std:: optional < U > && >
- std:: is_constructible_v < T, const std:: optional < U > && >
- std:: is_convertible_v < std:: optional < U > & , T >
- std:: is_convertible_v < const std:: optional < U > & , T >
- std:: is_convertible_v < std:: optional < U > && , T >
- std:: is_convertible_v < const std:: optional < U > && , T >
- std:: is_assignable_v < T & , std:: optional < U > & >
- std:: is_assignable_v < T & , const std:: optional < U > & >
- std:: is_assignable_v < T & , std:: optional < U > && >
- std:: is_assignable_v < T & , const std:: optional < U > && >
- Для перегрузки (4) , std:: is_constructible_v < T, const U & > и std:: is_assignable_v < T & , const U & > оба равны true .
- Для перегрузки (5) , std:: is_constructible_v < T, U > и std:: is_assignable_v < T & , U > оба имеют значение true .
- std:: decay_t < U > (до C++20) std:: remove_cvref_t < U > (начиная с C++20) не является std:: optional < T > .
- std:: is_constructible_v < T, U > равно true .
- std:: is_assignable_v < T & , U > равно true .
-
Выполняется любое из следующих условий:
-
Tне является скалярным типом . -
std::
decay_t
<
U
>
не является
T.
-
-
↑
Другими словами,
Tне является конструируемым, конвертируемым или присваиваемым из любого выражения типа (возможно const-квалифицированного) std:: optional < U >
Содержание |
Параметры
| other | - |
другой
optional
объект, чьё содержащееся значение нужно присвоить
|
| value | - | значение для присвоения содержащемуся значению |
Возвращаемое значение
* this
Исключения
T
. Если исключение выброшено, состояние инициализации
*
this
(и
other
в случае
(
2-5
)
) остается неизменным, т.е. если объект содержал значение, он продолжает содержать значение, и наоборот. Содержимое
value
и содержащиеся значения
*
this
и
other
зависят от гарантий безопасности исключений операции, из которой происходит исключение (конструктор копирования, перемещающее присваивание и т.д.).
std:: is_nothrow_move_constructible_v < T > )
Примечания
Необязательный объект
op
может быть преобразован в пустой опциональный объект с помощью как
op
=
{
}
;
, так и
op
=
nullopt
;
. Первое выражение создает пустой объект
optional
с помощью
{
}
и присваивает его
op
.
| Макрос тестирования возможностей | Значение | Стандарт | Функция |
|---|---|---|---|
__cpp_lib_optional
|
202106L
|
(C++20)
(DR20) |
Полностью constexpr ( 1 ) , ( 4-6 ) |
Пример
#include <iostream> #include <optional> int main() { std::optional<const char*> s1 = "abc", s2; // constructor s2 = s1; // assignment s1 = "def"; // decaying assignment (U = char[4], T = const char*) std::cout << *s2 << ' ' << *s1 << '\n'; }
Вывод:
abc def
Отчеты о дефектах
Следующие отчеты об изменениях в поведении, содержащие описания дефектов, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Применяется к | Поведение в опубликованной версии | Корректное поведение |
|---|---|---|---|
| LWG 3886 | C++17 |
аргумент шаблона по умолчанию для перегрузки
(
6
)
был
T
|
изменён на std:: remove_cv_t < T > |
| P0602R4 | C++17 |
оператор копирующего/перемещающего присваивания может не быть тривиальным
даже если базовые операции тривиальны |
требуется распространение тривиальности |
| P2231R1 | C++20 | перегрузки ( 1,4-6 ) не были constexpr | сделаны constexpr |
Смотрите также
|
создает содержащееся значение на месте
(публичная функция-член) |