9
9
unordered_map与unordered_multimap的源码在` unordered_map.h ` 这个文件中。
10
10
11
11
12
- ## 1.undered_map与unordered_multimap本质区别
13
- 先来看一下undered_map源码 :
12
+ ## 1.unordered_map与unordered_multimap本质区别
13
+ 先来看一下unordered_map源码 :
14
14
15
15
``` cpp
16
16
template <class _Key , class _ Tp,
@@ -51,13 +51,13 @@ typename _ExtractKey, typename _Equal,
51
51
typename _H1, typename _H2, typename _Hash,
52
52
typename _RehashPolicy, typename _Traits>
53
53
```
54
- 默认情况下,undered_map采用 :
54
+ 默认情况下,unordered_map采用 :
55
55
- H1为hash<key >
56
56
- H2为_Mod_range_hashing
57
57
- _ Hash为_Default_ranged_hash
58
58
- _ RehashPolicy为_Prime_rehash_policy
59
59
- _ Traits为_Tr
60
- 对于最后的_Tr,非常重要,因为正是因为这个参数,才有undered_multimap 。
60
+ 对于最后的_Tr,非常重要,因为正是因为这个参数,才有unordered_multimap 。
61
61
具体分析看下面:
62
62
63
63
@@ -91,7 +91,7 @@ struct _Hashtable_traits
91
91
using __unique_keys = __bool_constant<_Unique_keys>;
92
92
};
93
93
```
94
- 看到有三个using,理解为三个typedef,依次表示:hash code缓存与否,是否是常迭代器,是否是唯一的key,再往上回头看,传递进来的是三个模板参数,分别是false,false,true,也验证了undered_map是唯一的key,那么对应的undered_multimap就是不唯一的key ,最后一个参数为false。我们翻阅到相应代码如下:
94
+ 看到有三个using,理解为三个typedef,依次表示:hash code缓存与否,是否是常迭代器,是否是唯一的key,再往上回头看,传递进来的是三个模板参数,分别是false,false,true,也验证了unordered_map是唯一的key,那么对应的unordered_multimap就是不唯一的key ,最后一个参数为false。我们翻阅到相应代码如下:
95
95
96
96
``` cpp
97
97
// / Base types for unordered_multimap.
@@ -101,8 +101,8 @@ using __ummap_traits = __detail::_Hashtable_traits<_Cache, false, false>;
101
101
102
102
小结,在上面分析,我们知道了unordered_map与unordered_multimap的本质区别,也发现了如何在底层源码上用一个容器实现两个容器适配器!
103
103
104
- ## 2.undered_set与unordered_multiset本质区别
105
- 分析同前面一样,先看undered_set :
104
+ ## 2.unordered_set与unordered_multiset本质区别
105
+ 分析同前面一样,先看unordered_set :
106
106
107
107
``` cpp
108
108
template <class _Value ,
@@ -129,35 +129,35 @@ using __uset_hashtable = _Hashtable<_Value, _Value, _Alloc,
129
129
__ detail::_ Default_ranged_hash,
130
130
__ detail::_ Prime_rehash_policy, _ Tr>;
131
131
```
132
- 可以看到传递给`_Hashtable_traits`的是false,true,true。对于undered_set来说使用的是const iterator与唯一的key,我们再看一下unordered_multiset:
132
+ 可以看到传递给`_Hashtable_traits`的是false,true,true。对于unordered_set来说使用的是const iterator与唯一的key,我们再看一下unordered_multiset:
133
133
134
134
```cpp
135
135
template<bool _Cache>
136
136
using __umset_traits = __detail::_Hashtable_traits<_Cache, true, false>;
137
137
```
138
- 再将两者对比一下,本质就是undered_set不允许key重复,而undered_multiset允许key重复 。
138
+ 再将两者对比一下,本质就是unordered_set不允许key重复,而unordered_multiset允许key重复 。
139
139
140
140
## 3.三大结论
141
141
142
142
现在,我们有了前面基础,依次列出前面四个容器适配器:
143
143
144
- (1 ) undered_map
144
+ (1 ) unordered_map
145
145
```cpp
146
146
template <bool _Cache>
147
147
using __umap_traits = __detail::_Hashtable_traits<_Cache, false , true >;
148
148
```
149
- (2) undered_multimap
149
+ (2) unordered_multimap
150
150
``` cpp
151
151
template <bool _Cache>
152
152
using __umap_traits = __detail::_Hashtable_traits<_Cache, false , false >;
153
153
```
154
- (3) undered_set
154
+ (3) unordered_set
155
155
156
156
``` cpp
157
157
template <bool _Cache>
158
158
using __uset_traits = __detail::_Hashtable_traits<_Cache, true , true >;
159
159
```
160
- (4) undered_multiset
160
+ (4) unordered_multiset
161
161
162
162
``` cpp
163
163
template <bool _Cache>
@@ -166,13 +166,13 @@ using __uset_traits = __detail::_Hashtable_traits<_Cache, true, false>;
166
166
167
167
对比后,得出
168
168
169
- - 结论1:undered_map与undered_set不允许key重复 ,而带multi的则允许key重复;
170
- - 结论2:undered_map与undered_multimap采用的迭代器是iterator,而undered_set与undered_multiset采用的迭代器是const_iterator 。
171
- - 结论3:undered_map与undered_multimap的key是key ,value是key+value;而undered_set与undered_multiset的key是Value ,Value也是Key。
169
+ - 结论1:unordered_map与unordered_set不允许key重复 ,而带multi的则允许key重复;
170
+ - 结论2:unordered_map与unordered_multimap采用的迭代器是iterator,而unordered_set与unordered_multiset采用的迭代器是const_iterator 。
171
+ - 结论3:unordered_map与unordered_multimap的key是key ,value是key+value;而unordered_set与unordered_multiset的key是Value ,Value也是Key。
172
172
173
173
最后一个结论对比看下面(我们看传递给hashtable的第一与第二个参数):
174
174
175
- undered_map与undered_multimap :
175
+ unordered_map与unordered_multimap :
176
176
``` cpp
177
177
using __umap_hashtable = _Hashtable<_Key,
178
178
std::pair<const _Key, _Tp>,
@@ -182,7 +182,7 @@ __detail::_Mod_range_hashing,
182
182
__detail::_Default_ranged_hash,
183
183
__detail::_Prime_rehash_policy, _Tr>;
184
184
```
185
- undered_set与undered_multiset :
185
+ unordered_set与unordered_multiset :
186
186
``` cpp
187
187
template <typename _Value,
188
188
typename _Hash = hash<_Value>,
@@ -196,13 +196,13 @@ __detail::_Default_ranged_hash,
196
196
__detail::_Prime_rehash_policy, _Tr>;
197
197
```
198
198
199
- ## 4.undered_map重要函数
199
+ ## 4.unordered_map重要函数
200
200
201
201
> 初始化
202
202
203
- 可以在下面的构造函数中看到undered_map的默认桶数为10 。
203
+ 可以在下面的构造函数中看到unordered_map的默认桶数为10 。
204
204
205
- 在undered_map的底层默认采用hasher (),也就是H1,也就是std::hash
205
+ 在unordered_map的底层默认采用hasher (),也就是H1,也就是std::hash
206
206
207
207
``` cpp
208
208
unordered_map (size_type __ n = 10,
@@ -319,7 +319,7 @@ clear() noexcept
319
319
```
320
320
> hash_function
321
321
322
- 得到该undered_map的hash_function
322
+ 得到该unordered_map的hash_function
323
323
```cpp
324
324
hasher
325
325
hash_function() const
@@ -353,4 +353,4 @@ at(const key_type& __k)
353
353
```
354
354
除了这些函数还有获取桶,最大桶数、加载因子、rehash等等,就是没有排序,因为hashtable没有提供排序功能。hashtable在查找、删除和插入节点是常数时间,优于RB-Tree红黑树。
355
355
356
- 同理,unordered_set、unordered_multiset、unordered_multimap与undered_map一样的函数 ,所以就不阐述了。
356
+ 同理,unordered_set、unordered_multiset、unordered_multimap与unordered_map一样的函数 ,所以就不阐述了。
0 commit comments