命名空间
变体
操作

std::ranges::not_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)

约束比较器
ranges::not_equal_to
(C++20)
旧式绑定器和适配器
(直到 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 not_equal_to;
(since C++20)

用于执行比较的函数对象。从实参推导函数调用运算符的形参类型(但不推导返回类型)。

目录

[编辑] 嵌套类型

嵌套类型 定义
is_transparent 未指明

[编辑] 成员函数

operator()
检查实参是否不相等
(公共成员函数)

std::ranges::not_equal_to::operator()

template< class T, class U >
constexpr bool operator()( T&& t, U&& u ) const;

等价于 return !ranges::equal_to{}(std::forward<T>(t), std::forward<U>(u));

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

[编辑] 注解

std::not_equal_to 不同,std::ranges::not_equal_to 要求 ==!= 均为合法(通过 equality_comparable_with 约束),并且完全以 std::ranges::equal_to 定义。

[编辑] 示例

[编辑] 缺陷报告

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

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

[编辑] 参见

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