std::optional<T>:: operator=
|
optional
&
operator
=
(
std::
nullopt_t
)
noexcept
;
|
(1) |
(desde C++17)
(constexpr desde C++20) |
|
constexpr
optional
&
operator
=
(
const
optional
&
other
)
;
|
(2) | (desde C++17) |
|
constexpr
optional
&
operator
=
( optional && other ) noexcept ( /* ver más abajo */ ) ; |
(3) | (desde C++17) |
|
template
<
class
U
>
optional & operator = ( const optional < U > & other ) ; |
(4) |
(desde C++17)
(constexpr desde C++20) |
|
template
<
class
U
>
optional & operator = ( optional < U > && other ) ; |
(5) |
(desde C++17)
(constexpr desde C++20) |
|
template
<
class
U
=
std::
remove_cv_t
<
T
>
>
optional & operator = ( U && value ) ; |
(6) |
(desde C++17)
(constexpr desde C++20) |
Reemplaza el contenido de * this con el contenido de other .
val
-
>
T
::
~T
(
)
para destruir el valor contenido; de lo contrario no tiene efecto.
*
this
no contiene un valor después de esta llamada.
| Efecto | * this contiene un valor | * this no contiene un valor |
|---|---|---|
| other contiene un valor |
|
|
| other no contiene un valor |
destruye el valor contenido llamando
val
-
>
T
::
~T
(
)
|
sin efecto |
-
Los siguientes 12 valores son todos
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 > && >
- Para la sobrecarga (4) , std:: is_constructible_v < T, const U & > y std:: is_assignable_v < T & , const U & > son ambos true .
- Para la sobrecarga (5) , std:: is_constructible_v < T, U > y std:: is_assignable_v < T & , U > son ambos true .
- std:: decay_t < U > (hasta C++20) std:: remove_cvref_t < U > (desde C++20) no es std:: optional < T > .
- std:: is_constructible_v < T, U > es true .
- std:: is_assignable_v < T & , U > es true .
-
Se cumple alguna de las siguientes condiciones:
-
Tno es un tipo escalar . -
std::
decay_t
<
U
>
no es
T.
-
-
↑
En otras palabras,
Tno es construible, convertible, ni asignable desde ninguna expresión de tipo (posiblemente calificado como const) std:: optional < U >
Contenidos |
Parámetros
| otro | - |
otro objeto
optional
cuyo valor contenido asignar
|
| valor | - | valor a asignar al valor contenido |
Valor de retorno
* this
Excepciones
T
. Si se lanza una excepción, el estado de inicialización de
*
this
(y de
other
en el caso de
(
2-5
)
) permanece sin cambios, es decir, si el objeto contenía un valor, sigue conteniendo un valor, y viceversa. El contenido de
value
y los valores contenidos de
*
this
y
other
dependen de las garantías de seguridad ante excepciones de la operación desde la que se origina la excepción (constructor de copia, asignación de movimiento, etc.).
std:: is_nothrow_move_constructible_v < T > )
Notas
Un objeto opcional
op
puede convertirse en un optional vacío tanto con
op
=
{
}
;
como con
op
=
nullopt
;
. La primera expresión construye un objeto
optional
vacío con
{
}
y lo asigna a
op
.
| Macro de prueba de características | Valor | Std | Característica |
|---|---|---|---|
__cpp_lib_optional
|
202106L
|
(C++20)
(DR20) |
Completamente constexpr ( 1 ) , ( 4-6 ) |
Ejemplo
#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'; }
Salida:
abc def
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares publicados anteriormente de C++.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 3886 | C++17 |
el argumento de plantilla predeterminado de la sobrecarga
(
6
)
era
T
|
cambiado a std:: remove_cv_t < T > |
| P0602R4 | C++17 |
el operador de asignación de copia/traslado podría no ser trivial
incluso si las operaciones subyacentes son triviales |
requerido propagar trivialidad |
| P2231R1 | C++20 | las sobrecargas ( 1,4-6 ) no eran constexpr | convertidas en constexpr |
Véase también
|
construye el valor contenido in-situ
(función miembro pública) |