std::ranges::equal_to
来自cppreference.com
< cpp | utility | functional
定义于头文件 <functional>
|
||
struct equal_to; |
(C++20 起) | |
进行比较的函数对象。从参数推导函数调用运算符的形参类型(但非返回类型)。
成员类型
成员类型 | 定义 |
is_transparent
|
/* 未指定 */ |
成员函数
operator() |
检查参数是否相等 (公开成员函数) |
std::ranges::equal_to::operator()
template< class T, class U > requires std::equality_comparable_with<T, U> || |
||
比较 t
与 u
,等价于 return std::forward<T>(t) == std::forward<U>(u); ,除非该表达式解析成调用比较指针的内建 operator== 。
调用比较类型 P
指针的内建运算符时,结果以如下方式确定:
- 若第一参数的(可能为转换后的)值与第二参数的(可能为转换后的)值之一在
P
类型的所有指针值上的实现定义严格全序中前趋另一者,则返回 false 。此严格全序与内建运算符<
、>
、<=
及>=
所施加的偏序一致。 - 否则(无一前趋另一者),返回 true 。
行为未定义,除非从 T
与 U
到 P
的转换序列均保持相等性(见下方)。
相等性保持
若表达式对给定的相等输入产生相等输出,则它保持相等性。
- 表达式的输入由其运算数组成。
- 表达式的输出由其结果和表达式所修改的所有运算数(若存在)组成。
进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。
注意
不同于 std::equal_to , std::ranges::equal_to
要求 ==
与 !=
均合法(经由 equality_comparable_with 制约)。
示例
本节未完成 原因:暂无示例 |
参阅
实现 x == y 的函数对象 (类模板) |