std::ranges::less
来自 cppreference.cn
定义于头文件 <functional> |
||
struct less; |
(C++20 起) | |
用于执行比较的函数对象。从参数推导函数调用运算符的参数类型(但不推导返回类型)。
目录 |
[编辑] 嵌套类型
嵌套类型 | 定义 |
is_transparent
|
未指定 |
[编辑] 成员函数
operator() |
检查第一个参数是否小于第二个参数 (公开成员函数) |
std::ranges::less::operator()
template< class T, class U > constexpr bool operator()( T&& t, U&& u ) const; |
||
给定表达式 std::forward<T>(t) < std::forward<U>(u) 作为 expr
- 如果转换后的 t 在指针的实现定义严格全序中先于转换后的 u(两者都为类型
P
),返回 true,否则返回 false。 - 如果从
T
到P
的转换序列或从U
到P
的转换序列不是保持相等的,则行为未定义。
- 如果转换后的 t 在指针的实现定义严格全序中先于转换后的 u(两者都为类型
- 否则
- 返回 expr 的结果。
- 如果未建模 std::totally_ordered_with<T, U>,则行为未定义。
此重载仅在满足 std::totally_ordered_with<T, U> 时才参与重载决议。
如果存在类型为 T
的表达式 expr1 和类型为 U
的表达式 expr2,使得 expr1 和 expr2 的比较结果违反严格全序(规则定义如下),则行为未定义。
只有当以下表达式中恰好一个为 true 时,expr1 和 expr2 的比较结果才遵循严格全序:
- std::ranges::less{}(expr1, expr2)
- std::ranges::less{}(expr2, expr1)
- std::ranges::equal_to{}(expr1, expr2)
[编辑] 注意
与 std::less 不同,std::ranges::less
要求所有六个比较运算符 <
、<=
、>
、>=
、==
和 !=
都是有效的(通过 totally_ordered_with
约束)。
[编辑] 示例
本节不完整 原因:无示例 |
[编辑] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 3530 | C++20 | 比较指针时放宽了语法检查 | 仅放宽了语义要求 |
[编辑] 参阅
实现 x < y 的函数对象 (类模板) |