std::less<void>
来自cppreference.com
<tbody>
</tbody>
| 在标头 <functional> 定义
|
||
template<> class less<void>; |
(C++14 起) | |
std::less<void> 是会推导形参类型和返回类型的 std::less 特化。
嵌套类型
| 嵌套类型 | 定义 |
is_transparent
|
未指定 |
成员函数
测试 lhs 是否比较小于 rhs (公开成员函数) |
std::less<void>::operator()
<tbody> </tbody> template< class T, class U > constexpr auto operator()( T&& lhs, U&& rhs ) const -> decltype(std::forward<T>(lhs) < std::forward<U>(rhs)); |
||
返回 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 | 指针全序可能不一致 | 保证一致 |