std::experimental::ranges::equal_to
template< class T = void > requires EqualityComparable<T> || |
(ranges TS) | |
template<> struct equal_to<void>; |
(ranges TS) | |
用于执行比较的函数对象。主模板在 T
类型的 const 左值上调用 operator ==。 特化版 equal_to<void>
从参数推导函数调用运算符的形参类型(但不推导返回类型)。
equal_to
的所有特化版本均为 Semiregular
。
目录 |
[编辑] 成员类型
成员类型 | 定义 |
is_transparent (仅为 equal_to<void> 特化版本的成员) |
/* 未指定 */ |
[编辑] 成员函数
operator() |
检查实参是否相等 (公有成员函数) |
std::experimental::ranges::equal_to::operator()
constexpr bool operator()(const T& x, const T& y) const; |
(1) | (仅为主要 equal_to<T> 模板的成员) |
template< class T, class U > requires EqualityComparableWith<T, U> || |
(2) | (仅为 equal_to<void> 特化版本的成员) |
当调用 (1) 或 (2) 将会调用内置的运算符比较 P
类型的指针时,结果会改为如下方式确定:
- 如果第一个实参的(可能已转换的)值和第二个实参的(可能已转换的)值之一在实现定义的严格全序中先于另一个(此全序定义于所有
P
类型的指针值之上),则返回 false。此严格全序与内置运算符<
、>
、<=
和>=
施加的部分顺序一致。 - 否则(两者均不先于另一个),返回 true。
除非从 T
和 U
到 P
的转换序列都是相等保持的(见下文),否则行为未定义。
[编辑] 相等保持
如果一个表达式在给定相等输入时产生相等输出,则该表达式是相等保持的。
- 表达式的输入由其操作数组成。
- 表达式的输出由其结果和表达式修改的所有操作数(如果有)组成。
每个需要相等保持的表达式还必须是稳定的:在没有对这些输入对象进行任何显式中间修改的情况下,对具有相同输入对象的此类表达式的两次求值必须具有相等的输出。
[编辑] 注解
与 std::equal_to 不同,ranges::equal_to
要求 ==
和 !=
均为合法(通过 EqualityComparable
和 EqualityComparableWith
约束)。
[编辑] 示例
本节不完整 原因:没有示例 |
[编辑] 参见
实现 x == y 的函数对象 (类模板) |