operator==,!=(std::unordered_map)
來自 cppreference.com
template< class Key, class T, class Hash, class KeyEqual, class Alloc > bool operator==( const std::unordered_map<Key, T, Hash, KeyEqual, Alloc>& lhs, |
(1) | |
template< class Key, class T, class Hash, class KeyEqual, class Alloc > bool operator!=( const std::unordered_map<Key, T, Hash, KeyEqual, Alloc>& lhs, |
(2) | (C++20 前) |
比較兩個無序容器的內容。
當滿足以下條件時,兩個無序容器 lhs 和 rhs 的內容相等:
- lhs.size() == rhs.size().
- 從 lhs.equal_range(lhs_eq1) 獲得的每組等價元素
[
lhs_eq1,
lhs_eq2)
在另一個容器[
rhs_eq1,
rhs_eq2)
中都有一組相應的等價元素,該等價元素從 rhs.equal_range(rhs_eq1) 獲得,並具有以下屬性:
- std::distance(lhs_eq1, lhs_eq2) == std::distance(rhs_eq1, rhs_eq2).
- std::is_permutation(lhs_eq1, lhs_eq2, rhs_eq1) == true.
如果 Key
或 T
不滿足 EqualityComparable,則行為未定義。
如果 hash_function()
和 key_eq()
在(直到 C++20)key_eq()
在(從 C++20 開始) lhs 和 rhs 上沒有相同的行為,或者如果 Key
的 operator== 不是由 key_eq()
引入的等鍵組劃分的細化(即,如果使用 operator== 比較相等的兩個元素落入不同的劃分),則行為也未定義。
|
(C++20 起) |
[編輯] 引數
lhs, rhs | - | 要比較的無序容器 |
[編輯] 返回值
1) 如果容器內容相等則為 true,否則為 false。
2) 如果容器內容不相等則為 true,否則為 false。
[編輯] 複雜度
平均情況下,與對 value_type
呼叫 operator== N 次,對 key_eq
返回的謂詞進行呼叫,以及對 hash_function
返回的雜湊器進行呼叫成比例;在最壞情況下,與 N2 成比例,其中 N 是容器的大小。