std::greater<void>
From cppreference.com
< cpp | utility | functional
Defined in header <functional> | ||
template<> class greater<void>; | (since C++14) | |
std::greater<void> is a specialization of std::greater with parameter and return type deduced.
Contents |
[edit]Nested types
Nested type | Definition |
is_transparent | unspecified |
[edit]Member functions
operator() | tests if lhs compares greater than rhs (public member function) |
std::greater<void>::operator()
template<class T, class U > constexprauto operator()( T&& lhs, U&& rhs )const | ||
Returns the result of std::forward<T>(lhs)>std::forward<U>(rhs).
Parameters
lhs, rhs | - | values to compare |
Return value
std::forward<T>(lhs)>std::forward<U>(rhs).
If a built-in operator comparing pointers is called, the result is consistent with the implementation-defined strict total order over pointers.
[edit]Exceptions
May throw implementation-defined exceptions.
[edit]Example
Run this code
#include <algorithm>#include <cstdint>#include <functional> constexprbool strictly_positive(int lhs){returnstd::greater<>()(lhs, 0);} int main(){constexprstd::int64_t low =0B11;constexprstd::uint16_t high =0X11;std::greater<> greater{}; static_assert(greater(high, low)); constexprstaticauto arr ={0, 1, 2, 3, 4, 5}; static_assert(!std::all_of(arr.begin(), arr.end(), strictly_positive)); static_assert(std::all_of(arr.begin()+1, arr.end(), strictly_positive));}
[edit]Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 2562 | C++98 | the pointer total order might be inconsistent | guaranteed to be consistent |