C++ 参考手册

位置:首页 > > std::ranges::equal_to

定义于头文件 <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> ||
             /* std::declval<T>() == std::declval<U>() 解析到比较指针的内建运算符 */

constexpr bool operator()(T&& t, U&& u) const;

比较 tu ,等价于 return std::forward<T>(t) == std::forward<U>(u); ,除非该表达式解析成调用比较指针的内建 operator==

调用比较类型 P 指针的内建运算符时,结果以如下方式确定:

  • 若第一参数的(可能为转换后的)值与第二参数的(可能为转换后的)值之一在 P 类型的所有指针值上的实现定义严格全序中前趋另一者,则返回 false 。此严格全序与内建运算符 <><=>= 所施加的偏序一致。
  • 否则(无一前趋另一者),返回 true

行为未定义,除非从 TUP 的转换序列均保持相等性(见下方)。

相等性保持

若表达式对给定的相等输入产生相等输出,则它保持相等性

  • 表达式的输入由其运算数组成。
  • 表达式的输出由其结果和表达式所修改的所有运算数(若存在)组成。

进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。

注意

不同于 std::equal_tostd::ranges::equal_to 要求 ==!= 均合法(经由 equality_comparable_with 制约)。

示例

本节未完成
原因:暂无示例

参阅

实现 x == y 的函数对象
(类模板)