std::ranges::equal_to

来自cppreference.com
< cpp‎ | utility‎ | functional
 
 
 
函数对象
函数包装
(C++11)
(C++11)
部分函数应用
(C++11)
(C++20)
函数调用
(C++17)
恒等函数对象
(C++20)
引用包装
(C++11)(C++11)
运算符包装
取反器
(C++17)
搜索器
有制约的比较器
ranges::equal_to
(C++20)
旧绑定器与适配器
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)
(C++17 前)(C++17 前)(C++17 前)(C++17 前)
(C++20 前)
(C++20 前)
(C++17 前)(C++17 前)
(C++17 前)(C++17 前)

(C++17 前)
(C++17 前)(C++17 前)(C++17 前)(C++17 前)
(C++20 前)
(C++20 前)
 
定义于头文件 <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 的函数对象
(类模板) [编辑]