std::ranges::equal_to
来自 cppreference.cn
< cpp | utility | functional
定义于头文件 <functional> |
||
struct equal_to; |
(自 C++20 起) | |
用于执行比较的函数对象。函数调用运算符的形参类型(但非返回类型)从实参推导。
内容 |
[编辑] 嵌套类型
嵌套类型 | 定义 |
is_transparent
|
未指明 |
[编辑] 成员函数
operator() |
检查实参是否相等 (公有成员函数) |
std::ranges::equal_to::operator()
template< class T, class U > constexpr bool operator()( T&& t, U&& u ) const; |
||
给定表达式 std::forward<T>(t) == std::forward<U>(u) 为 expr
- 对于两个转换后的指针(类型为
P
),如果一个指针在 实现定义的指针严格全序中先于另一个,则返回 false,否则返回 true。 - 如果从
T
到P
的转换序列或从U
到P
的转换序列不是保等价的,则行为未定义。
- 对于两个转换后的指针(类型为
- 否则
- 返回 expr 的结果。
- 如果 std::equality_comparable_with<T, U> 未建模,则行为未定义。
此重载仅在 std::equality_comparable_with<T, U> 得到满足时参与重载决议。
[编辑] 注解
与 std::equal_to 相比,std::ranges::equal_to
额外要求 !=
有效,且两种实参类型都需要与自身(同质地)可比较(通过 equality_comparable_with
约束)。
[编辑] 示例
本节不完整 原因:没有示例 |
[编辑] 缺陷报告
下列行为更改缺陷报告被追溯应用到先前发布的 C++ 标准。
DR | 应用到 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 3530 | C++20 | 语法检查在比较指针时被放宽 | 只有语义要求被放宽 |
[编辑] 参见
实现 x == y 的函数对象 (类模板) |