Namensräume
Varianten
Aktionen

std::cmp_equal, cmp_not_equal, cmp_less, cmp_greater, cmp_less_equal, cmp_greater_equal

Von cppreference.com
< cpp‎ | utility
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
Ganzzahl-Vergleichsfunktionen
cmp_equalcmp_lesscmp_less_than
(C++20)(C++20)(C++20)  
cmp_not_equalcmp_greatercmp_greater_than
(C++20)(C++20)(C++20)
(C++20)
Swap und Typ-Operationen
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Gemeinsame Vokabulartypen
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)



 
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

1) true, wenn t gleich u ist.
2) true, wenn t nicht gleich u ist.
3) true, wenn t kleiner als u ist.
4) true, wenn t größer als u ist.
5) true, wenn t kleiner oder gleich u ist.
6) true, wenn t größer oder gleich u ist.

[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) [bearbeiten]
Funktions-Objekt, das x != y implementiert
(Klassen-Template) [bearbeiten]
Funktions-Objekt, das x < y implementiert
(Klassen-Template) [bearbeiten]
Funktions-Objekt, das x > y implementiert
(Klassen-Template) [bearbeiten]
Funktions-Objekt, das x <= y implementiert
(Klassen-Template) [bearbeiten]
Funktions-Objekt, das x >= y implementiert
(Klassen-Template) [bearbeiten]
Beschränktes Funktionsobjekt, das x == y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x != y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x < y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x > y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x <= y implementiert
(Klasse) [edit]
Beschränktes Funktionsobjekt, das x >= y implementiert
(Klasse) [edit]
beschränkte Funktionsobjekte, die x <=> y implementieren
(Klasse) [edit]
(C++20)
prüft, ob ein Ganzzahlwert im Bereich eines gegebenen Ganzzahltyps liegt
(Funktionsvorlage) [edit]
bietet eine Schnittstelle zur Abfrage von Eigenschaften aller fundamentalen numerischen Typen
(Klassenschablone) [bearbeiten]