Namespaces
Variants

std:: greater_equal<void>

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 greater_equal < void > ;
(seit C++14)

std:: greater_equal < void > ist eine Spezialisierung von std::greater_equal mit abgeleitetem Parameter- und Rückgabetyp.

Inhaltsverzeichnis

Verschachtelte Typen

Geschachtelter Typ Definition
is_transparent unspecified

Memberfunktionen

operator()
prüft, ob lhs größer oder gleich rhs verglichen wird
(public member function)

std::greater_equal<void>:: operator()

template < class T, class U >

constexpr auto operator ( ) ( T && lhs, U && rhs ) const

- > decltype ( std:: forward < T > ( lhs ) >= std:: forward < U > ( rhs ) ) ;

Gibt das Ergebnis von std:: forward < T > ( lhs ) >= std:: forward < U > ( rhs ) zurück.

Parameter

lhs, rhs - zu vergleichende Werte

Rückgabewert

std:: forward < T > ( lhs ) >= std:: forward < U > ( rhs ) .

Wenn ein eingebauter Operator zum Vergleichen von Zeigern aufgerufen wird, ist das Ergebnis konsistent mit der implementierungsdefinierten strengen Totalordnung über Zeiger .

Ausnahmen

Kann implementierungsdefinierte Ausnahmen werfen.

Beispiel

#include <algorithm>
#include <functional>
#include <initializer_list>
constexpr bool strictly_not_negative(int lhs)
{
    return std::greater_equal<>()(lhs, 0);
}
int main()
{
    constexpr int low = 0, high = 8;
    std::greater_equal<> greater_equal{};
    static_assert(greater_equal(high, low));
    static_assert(greater_equal(low, low));
    static constexpr auto arr = {-1, 0, 1, 2, 3, 4};
    static_assert(!std::all_of(arr.begin(), arr.end(), strictly_not_negative));
    static_assert(std::all_of(arr.begin() + 1, arr.end(), strictly_not_negative));
}

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