Namespaces
Variants

std:: less

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 T >
struct less ;
(bis C++14)
template < class T = void >
struct less ;
(seit C++14)

Funktionsobjekt zum Durchführen von Vergleichen. Die Hauptvorlage ruft operator < für den Typ T auf.

Inhaltsverzeichnis

Spezialisierungen

Funktionsobjekt, das x < y implementiert und Parameter- sowie Rückgabetypen ableitet
(Klassentemplate-Spezialisierung)

Mitgliedertypen

Typ Definition
result_type (veraltet in C++17) (entfernt in C++20) bool
first_argument_type (veraltet in C++17) (entfernt in C++20) T
second_argument_type (veraltet in C++17) (entfernt in C++20) T

Diese Member-Typen werden durch öffentliches Vererben von std:: binary_function < T, T, bool > erhalten.

(bis C++11)

Memberfunktionen

operator()
prüft, ob das erste Argument kleiner als das zweite ist
(öffentliche Elementfunktion)

std::less:: operator()

bool operator ( ) ( const T & lhs, const T & rhs ) const ;
(constexpr seit C++14)

Prüft, ob lhs kleiner als rhs ist.

Parameter

lhs, rhs - zu vergleichende Werte

Rückgabewert

lhs < rhs .

Falls T ein Zeigertyp ist, entspricht das Ergebnis der implementierungsdefinierten strengen Totalordnung für Zeiger .

Exceptions

Kann implementierungsdefinierte Exceptions werfen.

Mögliche Implementierung

constexpr bool operator()(const T& lhs, const T& rhs) const 
{
    return lhs < rhs; // assumes that the implementation handles pointer total order
}

Beispiel

#include <functional>
template<typename A, typename B, typename C = std::less<>>
constexpr bool fun(A a, B b, C cmp = C{})
{
    return cmp(a, b);
}
static_assert(fun(1, 2) == true);
static_assert(fun(1.0, 1) == false);
static_assert(fun(1, 2.0) == true);
static_assert(std::less<int>{}(5, 5.6) == false);   // 5 < 5 (Warnung: implizite Konvertierung)
static_assert(std::less<double>{}(5, 5.6) == true); // 5.0 < 5.6
static_assert(std::less<int>{}(5.6, 5.7) == false); // 5 < 5 (Warnung: implizite Konvertierung)
static_assert(std::less{}(5, 5.6) == true);         // less<void>: 5.0 < 5.6
int main() {}

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-Totalordnung könnte inkonsistent sein Konsistenz garantiert

Siehe auch

Funktionsobjekt, das x == y implementiert
(Klassentemplate)
Funktionsobjekt, das x > y implementiert
(Klassentemplate)
eingeschränktes Funktionsobjekt, das x < y implementiert
(Klasse)