命名空间
变体
操作

std::ranges::equal_to

来自 cppreference.cn
< cpp‎ | utility‎ | functional
 
 
 
函数对象
函数调用
(C++17)(C++23)
恒等函数对象
(C++20)
透明运算符包装器
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

旧式绑定器和适配器
(直到 C++17*)
(直到 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 >
constexpr bool operator()( T&& t, U&& u ) const;

给定表达式 std::forward<T>(t) == std::forward<U>(u)expr

  • 对于两个转换后的指针(类型为 P),如果一个指针在 实现定义的指针严格全序中先于另一个,则返回 false,否则返回 true
  • 如果从 TP 的转换序列或从 UP 的转换序列不是保等价的,则行为未定义。
  • 否则

此重载仅在 std::equality_comparable_with<T, U> 得到满足时参与重载决议。

[编辑] 注解

std::equal_to 相比,std::ranges::equal_to 额外要求 != 有效,且两种实参类型都需要与自身(同质地)可比较(通过 equality_comparable_with 约束)。

[编辑] 示例

[编辑] 缺陷报告

下列行为更改缺陷报告被追溯应用到先前发布的 C++ 标准。

DR 应用到 发布时的行为 正确的行为
LWG 3530 C++20 语法检查在比较指针时被放宽 只有语义要求被放宽

[编辑] 参见

实现 x == y 的函数对象
(类模板) [编辑]