Namespaces
Variants

std::ranges:: equal_to

From cppreference.net
Utilities library
Function objects
Function invocation
(C++17) (C++23)
Identity function object
(C++20)
Old binders and adaptors
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
( until C++17* ) ( until C++17* )
( until C++17* ) ( until C++17* )

( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
Definido en el encabezado <functional>
struct equal_to ;
(desde C++20)

Objeto función para realizar comparaciones. Los tipos de parámetros del operador de llamada a función (pero no el tipo de retorno) se deducen de los argumentos.

Contenidos

Tipos anidados

Tipo anidado Definición
is_transparent unspecified

Funciones miembro

operator()
verifica si los argumentos son iguales
(función miembro pública)

std::ranges::equal_to:: operator()

template < class T, class U >
constexpr bool operator ( ) ( T && t, U && u ) const ;

Dada la expresión std:: forward < T > ( t ) == std:: forward < U > ( u ) como expr :

  • De lo contrario:

Esta sobrecarga participa en la resolución de sobrecarga solo si std:: equality_comparable_with < T, U > se satisface.

Notas

En comparación con std::equal_to , std::ranges::equal_to requiere adicionalmente que != sea válido, y que ambos tipos de argumentos deben ser (homogéneamente) comparables consigo mismos (mediante la restricción equality_comparable_with ).

Ejemplo

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 3530 C++20 se relajaron las verificaciones sintácticas al comparar punteros solo se relajan los requisitos semánticos

Véase también

objeto de función que implementa x == y
(plantilla de clase)