名稱空間
變體
操作

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 呼叫 operator== N 次,對 key_eq 返回的謂詞進行呼叫,以及對 hash_function 返回的雜湊器進行呼叫成比例;在最壞情況下,與 N2 成比例,其中 N 是容器的大小。