std::ranges::not_equal_to

来自cppreference.com
< cpp‎ | utility‎ | functional
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
函数对象
函数包装
(C++11)
(C++11)
部分函数应用
(C++11)
(C++20)(C++23)
函数调用
(C++17)(C++23)
恒等函数对象
(C++20)
引用包装
(C++11)(C++11)
通透运算符包装
(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)
搜索器
受约束的比较器
ranges::not_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 not_equal_to;
(C++20 起)

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

实现定义的指针上的严格全序

若参数间的 = 运算符调用指针的内建比较运算符,则函数调用运算符产生实现定义的指针上的严格全序,即使内建的 = 运算符不如此。

实现定义的严格全序与比较运算符( <=><><=>= )所施加的偏序一致,并在下列标准函数对象间一致:

成员类型

成员类型 定义
is_transparent /* 未指定 */

成员函数

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

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

template< class T, class U >

    requires std::equality_comparable_with<T, U> // 有不同的语义要求

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

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

注解

不同于 std::not_equal_tostd::ranges::not_equal_to 要求 ==!= 均合法(经由 equality_comparable_with 约束),并且完全以 std::ranges::equal_to 定义。然而,实现有直接使用 operator!= 的自由,因为那些概念要求 ==!= 的结果一致。

示例

缺陷报告

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

缺陷报告 应用于 出版时的行为 正确行为
LWG 3530 C++20 在比较指针时放松了语法检查 仅放松语义要求

参阅

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