std::cmp_equal, cmp_not_equal, cmp_less, cmp_greater, cmp_less_equal, cmp_greater_equal
| Definiert in der Header-Datei <utility> |
||
| template< class T, class U > constexpr bool cmp_equal( T t, U u ) noexcept; |
(1) | (seit C++20) |
| template< class T, class U > constexpr bool cmp_not_equal( T t, U u ) noexcept; |
(2) | (seit C++20) |
| template< class T, class U > constexpr bool cmp_less( T t, U u ) noexcept; |
(3) | (seit C++20) |
| template< class T, class U > constexpr bool cmp_greater( T t, U u ) noexcept; |
(4) | (seit C++20) |
| template< class T, class U > constexpr bool cmp_less_equal( T t, U u ) noexcept; |
(5) | (seit C++20) |
| template< class T, class U > constexpr bool cmp_greater_equal( T t, U u ) noexcept; |
(6) | (seit C++20) |
Vergleicht die Werte zweier Ganzzahlen t und u. Im Gegensatz zu integrierten Vergleichsoperatoren sind negative vorzeichenbehaftete Ganzzahlen immer kleiner als (und nicht gleich) vorzeichenlose Ganzzahlen: der Vergleich ist sicher gegen nicht werterhaltende Ganzzahlkonvertierungen.
-1 > 0u; // true std::cmp_greater(-1, 0u); // false
Es ist ein Kompilierungsfehler, wenn entweder T oder U ein nicht-Ganzzahltyp, ein Zeichentyp oder bool ist.
Inhalt |
[bearbeiten] Parameter
| t | - | Argument auf der linken Seite |
| u | - | Argument auf der rechten Seite |
[bearbeiten] Rückgabewert
[bearbeiten] Mögliche Implementierung
template<class T, class U> constexpr bool cmp_equal(T t, U u) noexcept { if constexpr (std::is_signed_v<T> == std::is_signed_v<U>) return t == u; else if constexpr (std::is_signed_v<T>) return t >= 0 && std::make_unsigned_t<T>(t) == u; else return u >= 0 && std::make_unsigned_t<U>(u) == t; } template<class T, class U> constexpr bool cmp_not_equal(T t, U u) noexcept { return !cmp_equal(t, u); } template<class T, class U> constexpr bool cmp_less(T t, U u) noexcept { if constexpr (std::is_signed_v<T> == std::is_signed_v<U>) return t < u; else if constexpr (std::is_signed_v<T>) return t < 0 || std::make_unsigned_t<T>(t) < u; else return u >= 0 && t < std::make_unsigned_t<U>(u); } template<class T, class U> constexpr bool cmp_greater(T t, U u) noexcept { return cmp_less(u, t); } template<class T, class U> constexpr bool cmp_less_equal(T t, U u) noexcept { return !cmp_less(u, t); } template<class T, class U> constexpr bool cmp_greater_equal(T t, U u) noexcept { return !cmp_less(t, u); } |
[bearbeiten] Hinweise
Diese Funktionen können nicht zum Vergleichen von Aufzählungen (einschließlich std::byte), char, char8_t, char16_t, char32_t, wchar_t und bool verwendet werden.
| Feature-Test-Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_integer_comparison_functions |
202002L |
(C++20) | Ganzzahl-Vergleichsfunktionen |
[bearbeiten] Beispiel
Das folgende Beispiel kann eine Warnung für unterschiedliche Vorzeichenbehaftung beim Vergleichen ausgeben, wenn es ohne ein entsprechendes Flag zur Unterdrückung von Warnungen kompiliert wird, z. B. -Wno-sign-compare (gcc/clang mit -Wall -Wextra, siehe auch SO: disabling a specific warning).
#include <utility> // Uncommenting the next line will disable "signed/unsigned comparison" warnings: // #pragma GCC diagnostic ignored "-Wsign-compare" int main() { static_assert(sizeof(int) == 4); // precondition // Quite surprisingly static_assert(-1 > 1U); //< warning: sign-unsign comparison // because after implicit conversion of -1 to the RHS type (`unsigned int`) // the expression is equivalent to: static_assert(0xFFFFFFFFU > 1U); static_assert(0xFFFFFFFFU == static_cast<unsigned>(-1)); // In contrast, the cmp_* family compares integers as most expected - // negative signed integers always compare less than unsigned integers: static_assert(std::cmp_less(-1, 1U)); static_assert(std::cmp_less_equal(-1, 1U)); static_assert(!std::cmp_greater(-1, 1U)); static_assert(!std::cmp_greater_equal(-1, 1U)); static_assert(-1 == 0xFFFFFFFFU); //< warning: sign-unsign comparison static_assert(std::cmp_not_equal(-1, 0xFFFFFFFFU)); }
[bearbeiten] Siehe auch
| Funktions-Objekt, das x == y implementiert (Klassen-Template) | |
| Funktions-Objekt, das x != y implementiert (Klassen-Template) | |
| Funktions-Objekt, das x < y implementiert (Klassen-Template) | |
| Funktions-Objekt, das x > y implementiert (Klassen-Template) | |
| 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) |
| (C++20) |
Beschränktes Funktionsobjekt, das x != y implementiert (Klasse) |
| (C++20) |
Beschränktes Funktionsobjekt, das x < y implementiert (Klasse) |
| (C++20) |
Beschränktes Funktionsobjekt, das x > y implementiert (Klasse) |
| (C++20) |
Beschränktes Funktionsobjekt, das x <= y implementiert (Klasse) |
| (C++20) |
Beschränktes Funktionsobjekt, das x >= y implementiert (Klasse) |
| (C++20) |
beschränkte Funktionsobjekte, die x <=> y implementieren (Klasse) |
| (C++20) |
prüft, ob ein Ganzzahlwert im Bereich eines gegebenen Ganzzahltyps liegt (Funktionsvorlage) |
| bietet eine Schnittstelle zur Abfrage von Eigenschaften aller fundamentalen numerischen Typen (Klassenschablone) |