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* )
Definiert im Header <functional>
template <>
class less < void > ;
(seit C++14)

std:: less < void > ist eine Spezialisierung von std::less mit abgeleitetem Parameter- und Rückgabetyp.

Inhaltsverzeichnis

Verschachtelte Typen

Geschachtelter Typ Definition
is_transparent unspecified

Memberfunktionen

operator()
prüft, ob lhs kleiner als rhs verglichen wird
(öffentliche Elementfunktion)

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 ) ) ;

Gibt das Ergebnis von std:: forward < T > ( lhs ) < std:: forward < U > ( rhs ) zurück.

Parameter

lhs, rhs - zu vergleichende Werte

Rückgabewert

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

Wenn ein eingebauter Operator zum Vergleichen von Zeigern aufgerufen wird, ist das Ergebnis konsistent mit der implementierungsdefinierten strengen Totalordnung über Zeiger .

Ausnahmen

Kann implementierungsdefinierte Ausnahmen werfen.

Beispiel

#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));
}

Fehlerberichte

Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR Angewendet auf Verhalten wie veröffentlicht Korrektes Verhalten
LWG 2562 C++98 die Zeiger-Gesamtordnung könnte inkonsistent sein Konsistenz garantiert