命名空间
变体
操作

operator==, !=(std::unordered_map)

来自 cppreference.com
< cpp‎ | 容器‎ | 无序映射
 
 
 
 
template< class Key, class T, class Hash, class KeyEqual, class Alloc >

bool operator==( const std::unordered_map<Key, T, Hash, KeyEqual, Alloc>& lhs,

                 const std::unordered_map<Key, T, Hash, KeyEqual, Alloc>& rhs );
(1)
template< class Key, class T, class Hash, class KeyEqual, class Alloc >

bool operator!=( const std::unordered_map<Key, T, Hash, KeyEqual, Alloc>& lhs,

                 const std::unordered_map<Key, T, Hash, KeyEqual, Alloc>& rhs );
(2) (直到 C++20)

比较两个无序容器的内容。

如果满足以下条件,则两个无序容器 lhsrhs 的内容相等

  • lhs.size() == rhs.size().
  • lhs.equal_range(lhs_eq1) 获得的每个等效元素组 [lhs_eq1lhs_eq2) 在另一个容器中都有一个相应的等效元素组 [rhs_eq1rhs_eq2),该组是从 rhs.equal_range(rhs_eq1) 获得的,并且具有以下属性

如果 KeyT 不是 EqualityComparable,则行为未定义。

如果 hash_function()key_eq()(直到 C++20)key_eq()(自 C++20 以来) lhsrhs 上没有相同的行为,或者如果 Keyoperator== 不是由 key_eq() 引入的等效键组分区细化(也就是说,如果两个使用 operator== 进行比较相等的元素落入不同的分区),则行为也未定义。

!= 运算符是 operator== 合成的

(自 C++20 以来)

[编辑] 参数

lhs, rhs - 要比较的无序容器

[编辑] 返回值

1) true 如果容器的内容相等,否则为 false
2) true 如果容器的内容不相等,否则为 false

[编辑] 复杂度

value_type 上的 Noperator== 调用、由 key_eq 返回的谓词调用以及由 hash_function 返回的哈希器调用成比例,在平均情况下,与 N2 成比例,其中 N 是容器的大小。