Namespaces
Variants

std::ranges:: not_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 not_equal_to ;
(desde C++20)

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

Contenidos

Tipos anidados

Tipo anidado Definición
is_transparent unspecified

Funciones miembro

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

std::ranges::not_equal_to:: operator()

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

Equivalente a return ! ranges:: equal_to { } ( std:: forward < T > ( t ) , std:: forward < U > ( u ) ) ; .

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

Notas

A diferencia de std::not_equal_to , std::ranges::not_equal_to requiere que tanto == como != sean válidos (a través de la restricción equality_comparable_with ), y está completamente definido en términos de std::ranges::equal_to .

Ejemplo

Informes de defectos

Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.

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 función que implementa x ! = y
(plantilla de clase)