Espacios de nombres
Variantes

operator==(std::expected)

De cppreference.com
 
 
Biblioteca de servicios
 
 
Plantilla primaria
template< class T2, class E2 > requires (!std::is_void_v<T2>) friend constexpr bool operator==( const expected& lhs, const std::expected<T2, E2>& rhs );
(1) (desde C++23)
template< class E2 > friend constexpr bool operator==( const expected& lhs, const std::unexpected<E2>& unex );
(2) (desde C++23)
template< class T2 > friend constexpr bool operator==( const expected& lhs, const T2& val );
(3) (desde C++23)
Especialización parcial void
template< class T2, class E2 > requires std::is_void_v<T2> friend constexpr bool operator==( const expected& lhs, const std::expected<T2, E2>& rhs );
(4) (desde C++23)
template< class E2 > friend constexpr bool operator==( const expected& lhs, const std::unexpected<E2>& unex );
(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 bool, el programa es malformado:

(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 bool:

(desde C++26)
  • *lhs == *rhs
  • lhs.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 lhs.error() == unex.error() es malformada, o su resultado no es convertible a bool, el programa es malformado.

(hasta C++26)

Esta sobrecarga solo participa en la resolución de sobrecargas si la expresión lhs.error() == unex.error() es bien formada, y su resultado es convertible a bool.

(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 *lhs == val es malformada, o su resultado no es convertible a bool, el programa es malformado.

(hasta C++26)

Esta sobrecarga solo participa en la resolución de sobrecargas si todas las siguientes condiciones se cumplen:

  • T2 no es una especialización de std::expected.
  • La expresión *lhs == val es bien formada, y su resultado es convertible a bool.
(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 lhs.error() == rhs.error() es malformada, o su resultado no es convertible a bool, el programa es malformado.

(hasta C++26)

Esta sobrecarga solo participa en la resolución de sobrecargas si la expresión lhs.error() == rhs.error() es bien formada, y su resultado es convertible a bool.

(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 lhs.error() == unex.error() es malformada, o su resultado no es convertible a bool, el programa es malformado.

(hasta C++26)

Esta sobrecarga solo participa en la resolución de sobrecargas si la expresión lhs.error() == unex.error() es bien formada, y su resultado es convertible a bool.

(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 std::expected<T, E> es una clase asociada de los argumentos.

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):
💚 == 💚
💚 != ❌

Véase también

Representado como un valor no esperado.
(plantilla de clase) [editar]