Namespaces
Variants

std::experimental::ranges:: not_equal_to

From cppreference.net
template < class T = void >

requires EqualityComparable < T > ||
Same < T, void > ||
/* == 对两个 const T 左值的操作调用内置的指针比较运算符 */

struct not_equal_to ;
(ranges TS)
template <>
struct not_equal_to < void > ;
(ranges TS)

用于执行比较的函数对象。主模板在类型 T 的常量左值上调用 operator == 并对结果取反。特化版本 not_equal_to<void> 会从参数推导函数调用运算符的参数类型(但不推导返回类型)。

所有 not_equal_to 的特化都满足 Semiregular 概念。

目录

成员类型

成员类型 定义
is_transparent (仅属于 not_equal_to<void> 特化的成员) /* 未指定 */

成员函数

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

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

constexpr bool operator ( ) ( const T & x, const T & y ) const ;
(1) (仅主模板 not_equal_to<T> 的成员)
template < class T, class U >

requires EqualityComparableWith < T, U > ||
/* std::declval<T>() == std::declval<U>() resolves to
a built-in operator comparing pointers */

constexpr bool operator ( ) ( T && t, U && u ) const ;
(2) (仅特化模板 not_equal_to<void> 的成员)
1) 比较 x y 。等价于 return ! ranges:: equal_to <> { } ( x, y ) ;
2) 比较 t u 。等价于 return ! ranges:: equal_to <> { } ( std:: forward < T > ( t ) , std:: forward < U > ( u ) ) ;

注释

std::not_equal_to 不同, ranges::not_equal_to 要求 == != 都必须有效(通过 EqualityComparable EqualityComparableWith 约束实现),并且完全基于 ranges::equal_to 定义。不过,实现可以直接使用 operator ! = ,因为这些概念要求 == != 的运算结果必须保持一致。

示例

参见

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