std::less<void>
来自cppreference.com
< cpp | utility | functional
在标头 <functional> 定义
|
||
template<> class less<void>; |
(C++14 起) | |
std::less<void> 是会推导形参类型和返回类型的 std::less 特化。
嵌套类型
嵌套类型 | 定义 |
is_transparent
|
未指定 |
成员函数
operator() |
测试 lhs 是否比较小于 rhs (公开成员函数) |
std::less<void>::operator()
template< class T, class U > constexpr auto operator()( T&& lhs, U&& rhs ) const |
||
返回 std::forward<T>(lhs) < std::forward<U>(rhs) 的结果。
参数
lhs, rhs | - | 要比较的值 |
返回值
std::forward<T>(lhs) < std::forward<U>(rhs)。
如果调用了内建的运算符比较指针,那么结果会与由实现定义的指针严格全序保持一致。
异常
可能会抛出由实现定义的异常。
示例
运行此代码
#include <algorithm> #include <functional> constexpr bool strictly_negative(int lhs) { return std::less<>()(lhs, 0); } int main() { constexpr signed low = 010; constexpr unsigned high = 10; std::less<> less{}; static_assert(less(low, high)); constexpr static auto arr = {0, -1, -2, -3, -4, -5}; static_assert(!std::all_of(arr.begin(), arr.end(), strictly_negative)); static_assert(std::all_of(arr.begin() + 1, arr.end(), strictly_negative)); }
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 2562 | C++98 | 指针全序可能不一致 | 保证一致 |