std::less_equal<void>
Von cppreference.com
< cpp | utility | functional
| Definiert in der Header-Datei <functional> |
||
| template<> class less_equal<void>; |
(seit C++14) | |
std::less_equal<void> ist eine Spezialisierung von std::less_equal, bei der Parameter- und Rückgabetyp abgeleitet werden.
Inhalt |
[bearbeiten] Verschachtelte Typen
| Verschachtelter Typ | Definition |
is_transparent
|
nicht spezifiziert |
[bearbeiten] Member-Funktionen
| operator() |
prüft, ob lhs kleiner oder gleich rhs ist (öffentliche Memberfunktion) |
std::less_equal<void>::operator()
| template< class T, class U > constexpr auto operator()( T&& lhs, U&& rhs ) const |
||
Gibt das Ergebnis von std::forward<T>(lhs) <= std::forward<U>(rhs) zurück.
Parameter
| lhs, rhs | - | Werte zum Vergleichen |
Rückgabewert
std::forward<T>(lhs) <= std::forward<U>(rhs).
Wenn ein eingebauter Operator aufgerufen wird, der Zeiger vergleicht, ist das Ergebnis konsistent mit der implementierungsdefinierten strengen Totalordnung für Zeiger.
[edit] Exceptions
Kann implementierungsdefinierte Ausnahmen auslösen.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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)); }
[bearbeiten] Fehlerberichte
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 |