CppDS.com

C++ 98 11 14 17 20 手册

std::experimental::ranges::not_equal_to

来自cppreference.com
< cpp‎ | experimental‎ | ranges
 
 
技术规范
文件系统库 (文件系统 TS)
库基础 (库基础 TS)
库基础 2 (库基础 TS v2)
库基础 3 (库基础 TS v3)
并行扩展 (并行 TS)
并行扩展 2 (并行 TS v2)
并发扩展 (并发 TS)
概念 (概念 TS)
范围 (范围 TS)
数学特殊函数 (特殊函数 TR)
 
 
通用工具库
工具组件
函数对象
not_equal_to
元编程与类型特性
有标签的 pair 与 tuple
                          
标签说明符
                                      
                          
 
template< class T = void >

    requires ranges::EqualityComparable<T> ||
             ranges::Same<T, void> ||
             /* 二个 const T 左值上的 == 调用比较指针的内建运算符 */

struct not_equal_to;
(范围 TS)
template <>
struct not_equal_to<void>;
(范围 TS)

进行比较的函数对象。初等模板在 T 类型 const 左值上调用 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 ranges::EqualityComparableWith<T, U> ||
             /* std::declval<T>() == std::declval<U>()
                解析成比较指针的内建运算符 */

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

注意

不同于 std::not_equal_toranges::not_equal_to 要求 ==!= 均合法(通过 EqualityComparableEqualityComparableWith 制约),而它完全用 ranges::equal_to 定义。然而,实现可以自由地直接使用 operator!= ,因为这些概念要求 ==!= 的结果一致。

示例

参阅

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