Namespaces
Variants

std:: less<void>

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>
template <>
class less < void > ;
(desde C++14)

std:: less < void > es una especialización de std::less con tipo de parámetro y retorno deducidos.

Contenidos

Tipos anidados

Tipo anidado Definición
is_transparent unspecified

Funciones miembro

operator()
prueba si lhs es menor que rhs
(función miembro pública)

std::less<void>:: operator()

template < class T, class U >

constexpr auto operator ( ) ( T && lhs, U && rhs ) const

- > decltype ( std:: forward < T > ( lhs ) < std:: forward < U > ( rhs ) ) ;

Devuelve el resultado de std:: forward < T > ( lhs ) < std:: forward < U > ( rhs ) .

Parámetros

lhs, rhs - valores a comparar

Valor de retorno

std:: forward < T > ( lhs ) < std:: forward < U > ( rhs ) .

Si se llama a un operador incorporado que compara punteros, el resultado es consistente con el orden total estricto definido por la implementación sobre punteros .

Excepciones

Puede lanzar excepciones definidas por la implementación.

Ejemplo

#include <algorithm>
#include <functional>
constexpr bool strictly_negative(int lhs)
{
    return std::less<>()(lhs, 0);
}
int main()
{
    constexpr signed low = 010;
    constexpr unsigned high = 10;
    std::less<> less{};
    static_assert(less(low, high));
    constexpr static auto arr = {0, -1, -2, -3, -4, -5};
    static_assert(!std::all_of(arr.begin(), arr.end(), strictly_negative));
    static_assert(std::all_of(arr.begin() + 1, arr.end(), strictly_negative));
}

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 2562 C++98 el orden total de punteros podría ser inconsistente garantizado ser consistente