Namespaces
Variants

std:: less_equal<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_equal < void > ;
(desde C++14)

std:: less_equal < void > es una especialización de std::less_equal 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 o igual que rhs
(función miembro pública)

std::less_equal<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>
#include <initializer_list>
constexpr bool strictly_not_positive(int lhs)
{
    return std::less_equal<>()(lhs, 0);
}
int main()
{
    constexpr int low = 0, high = 8;
    std::less_equal<> less_equal{};
    static_assert(less_equal(low, high));
    static_assert(less_equal(low, low));
    static constexpr auto arr = {1, 0, -1, -2, -3, -4};
    static_assert(!std::all_of(arr.begin(), arr.end(), strictly_not_positive));
    static_assert(std::all_of(arr.begin() + 1, arr.end(), strictly_not_positive));
}

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