std::less
Von cppreference.com
< cpp | utility | functional
| Definiert in der Header-Datei <functional> |
||
template< class T > struct less; |
(bis C++14) | |
| template< class T = void > struct less; |
(seit C++14) | |
Objekt für Funktionsaufrufe zur Durchführung von Vergleichen. Die Hauptvorlage ruft operator< für den Typ T auf.
Inhalt |
[edit] Spezialisierungen
| (C++14) |
Objekt für Funktionsaufrufe, das x < y implementiert, indem Parameter- und Rückgabetypen abgeleitet werden (Klassenvorlagenspezialisierung) |
[edit] Mitgliedertypen
| Typ | Definition |
result_type (deprecated in C++17)(removed in C++20) |
bool |
first_argument_type (deprecated in C++17)(removed in C++20) |
T
|
second_argument_type (deprecated in C++17)(removed in C++20) |
T
|
|
Diese Mitgliedertypen werden durch öffentliche Vererbung von std::binary_function<T, T, bool> erhalten. |
(bis C++11) |
[edit] Mitgliederfunktionen
| operator() |
prüft, ob das erste Argument kleiner als das zweite ist (öffentliche Memberfunktion) |
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 | - | Werte zum Vergleichen |
Rückgabewert
lhs < rhs.
Wenn T ein Zeigertyp ist, ist das Ergebnis konsistent mit der implementierungsdefinierten strikten totalen Ordnung über Zeiger.
[edit] Exceptions
Kann implementierungsdefinierte Ausnahmen auslösen.
Mögliche Implementierung
constexpr bool operator()(const T& lhs, const T& rhs) const { return lhs < rhs; // assumes that the implementation handles pointer total order } |
[edit] Beispiel
Führen Sie diesen Code aus
#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 (warn: implicit conversion) 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 (warn: implicit conversion) static_assert(std::less{}(5, 5.6) == true); // less<void>: 5.0 < 5.6 int main() {}
[edit] Defect reports
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 2562 | C++98 | die Zeiger-Totalordnung könnte inkonsistent sein | garantiert konsistent zu sein |
[edit] Siehe auch
| Funktions-Objekt, das x == y implementiert (Klassen-Template) | |
| Funktions-Objekt, das x > y implementiert (Klassen-Template) | |
| (C++20) |
Beschränktes Funktionsobjekt, das x < y implementiert (Klasse) |