operator==(std::expected) - cppreference.com
De cppreference.com
| Plantilla primaria |
||
|
|
(1) | (desde C++23) |
|
|
(2) | (desde C++23) |
|
|
(3) | (desde C++23) |
| Especialización parcial |
||
|
|
(4) | (desde C++23) |
|
|
(5) | (desde C++23) |
Realiza operaciones de comparación en objetos std::expected.
1) Compara dos objetos std::expected. Los objetos se consideran iguales si y solo si tanto lhs como rhs contienen valores esperados que son iguales, o ambos contienen valores no esperados que son iguales.
|
Si alguna de las siguientes expresiones es malformada, o su resultado no es convertible a |
(hasta C++26) |
|
Esta sobrecarga solo participa en la resolución de sobrecargas si todas las siguientes expresiones son bien formadas, y sus resultados son convertibles a |
(desde C++26) |
*lhs == *rhslhs.error() == rhs.error()
2) Compara un objeto std::expected con un objeto std::unexpected. Los objetos se consideran iguales si y solo si lhs contiene un valor no esperado que es igual a unex.error().
|
Si la expresión |
(hasta C++26) |
|
Esta sobrecarga solo participa en la resolución de sobrecargas si la expresión |
(desde C++26) |
3) Compara un objeto std::expected con un valor esperado. Los objetos se consideran iguales si y solo si lhs contiene un valor esperado que es igual a val.
|
Si la expresión |
(hasta C++26) |
|
Esta sobrecarga solo participa en la resolución de sobrecargas si todas las siguientes condiciones se cumplen:
|
(desde C++26) |
4) Compara dos objetos std::expected. Los objetos se consideran iguales si y solo si lhs y rhs ambos representan valores esperados, o ambos contienen valores no esperados que son iguales.
|
Si la expresión |
(hasta C++26) |
|
Esta sobrecarga solo participa en la resolución de sobrecargas si la expresión |
(desde C++26) |
5) Compara un objeto std::expected con un objeto std::unexpected. Los objetos se consideran iguales si y solo si lhs contiene un valor no esperado que es igual a unex.error().
|
Si la expresión |
(hasta C++26) |
|
Esta sobrecarga solo participa en la resolución de sobrecargas si la expresión |
(desde C++26) |
Estas funciones no son visibles a una búsqueda no calificada o calificada, y pueden encontrarse solamente mediante la búsqueda dependiente de argumento cuando es una clase asociada de los argumentos.
std::expected<T, E>
El operador != se sintetiza a partir de operator==.
Parámetros
| lhs, rhs | - | Objeto(s) std::expected a comparar. |
| unex | - | Valor std::unexpected a comparar con lhs.
|
| val | - | Valor a comparar con el valor esperado contenido en lhs.
|
Valor de retorno
1) lhs.has_value() != rhs.has_value() ? false :(lhs.has_value() ? *lhs == *rhs : lhs.error() == rhs.error())
2) !lhs.has_value() && static_cast<bool>(lhs.error() == unex.error())
3) lhs.has_value() && static_cast<bool>(*lhs == val)
4) lhs.has_value() != rhs.has_value() ? false :lhs.has_value() || static_cast<bool>(lhs.error() == rhs.error())
5) !lhs.has_value() && static_cast<bool>(lhs.error() == unex.error())
Excepciones
Lanza cuando y lo que la comparación lanza.
Notas
| Macro de Prueba de característica | Valor | Estándar | Comentario |
|---|---|---|---|
__cpp_lib_constrained_equality |
202411L |
(C++26) | Operadores de comparación restringidos para std::expected. |
Ejemplo
#include <expected> #include <iostream> #include <string_view> using namespace std::string_view_literals; int main() { auto x1{"\N{CORAZÓN VERDE}"sv}; auto x2{"\N{MARCA DE CRUZ}"sv}; std::expected<std::string_view, int> e1{x1}, e2{x1}, e3{x2}; std::unexpected u1{13}; std::cout << "Sobrecarga (1):\n" << e1.value() << (e1 == e2 ? " == " : " != ") << *e2 << '\n' << e1.value() << (e1 != e3 ? " != " : " == ") << *e3 << "\n\n"; std::cout << "Sobrecarga (2):\n" << e1.value() << (e1 == u1 ? " == " : " != ") << u1.error() << '\n'; e1 = std::unexpected{13}; std::cout << e1.error() << (e1 == u1 ? " == " : " != ") << u1.error() << '\n'; e1 = std::unexpected{31}; std::cout << e1.error() << (e1 != u1 ? " != " : " == ") << u1.error() << '\n'; std::cout << "Sobrecarga (3):\n" << *e1 << (e1 == x1 ? " == " : " != ") << x1 << '\n' << *e1 << (e1 != x2 ? " != " : " == ") << x2 << "\n\n"; }
Salida:
Sobrecarga (1): 💚 == 💚 💚 != ❌ Sobrecarga (2): 💚 != 13 13 == 13 31 != 13 Sobrecarga (3): 💚 == 💚 💚 != ❌