C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- std::array
- std::vector
- std::map
- std::unordered_map
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::operator[]
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::get_allocator
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::begin, std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::cbegin
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::empty
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::end, std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::cend
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::unordered_map
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::~unordered_map
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::operator=
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::size
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::max_size
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::clear
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::insert
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::insert_or_assign
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::emplace
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::emplace_hint
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::try_emplace
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::erase
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::swap
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::extract
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::merge
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::at
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::count
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::find
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::contains
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::equal_range
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::begin(size_type), std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::cbegin(size_type)
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::end(size_type), std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::cend(size_type)
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::bucket_count
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::max_bucket_count
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::bucket_size
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::bucket
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::load_factor
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::max_load_factor
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::rehash
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::reserve
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::hash_function
- std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::key_eq
- operator==,!=(std::unordered_map)
- std::swap(std::unordered_map)
- std::erase_if (std::unordered_map)
- std::unordered_map çæ¨å¯¼æå¼
- std::priority_queue
- std::span
- std::forward_list
- std::deque
- std::list
- std::set
- std::multiset
- std::multimap
- std::unordered_set
- std::unordered_multiset
- std::unordered_multimap
- std::stack
- std::queue
- std::vector<bool>
- ç»ç¹ææ (C++17)
- 注é
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >容å¨åº > std::unordered_map
std::unordered_map
  class Key,
  class T,
  class Hash = std::hash<Key>,
  class KeyEqual = std::equal_to<Key>,
  class Allocator = std::allocator< std::pair<const Key, T> >
  template <class Key,
       class T,
       class Hash = std::hash<Key>,
       class KeyEqual = std::equal_to<Key>>
       using unordered_map = std::unordered_map<Key, T, Hash, Pred,
               std::pmr::polymorphic_allocator<std::pair<const Key,T>>>;
unordered_map æ¯å ³è容å¨ï¼å«æå¸¦å¯ä¸é®çé®-å¼ pair ãæç´¢ãæå ¥åå ç´ ç§»é¤æ¥æå¹³åå¸¸æ°æ¶é´å¤æåº¦ã
å ç´ å¨å é¨ä¸ä»¥ä»»ä½ç¹å®é¡ºåºæåºï¼èæ¯ç»ç»è¿æ¡¶ä¸ãå ç´ æ¾è¿åªä¸ªæ¡¶å®å ¨ä¾èµäºå ¶é®çåå¸ãè¿å 许对åç¬å ç´ çå¿«é访é®ï¼å ä¸ºä¸æ¦è®¡ç®åå¸ï¼åå®åç¡®æä»£å ç´ ææ¾è¿çæ¡¶ã
std::unordered_map æ»¡è¶³å®¹å¨ (Container) ãå
·åé
å¨å®¹å¨ (AllocatorAwareContainer) ãæ åºå
³èå®¹å¨ (UnorderedAssociativeContainer) çè¦æ±ã
è¿ä»£å¨éæ³å
| æä½ | éæ³å |
|---|---|
| ææåªè¯»æä½ã swap ã std::swap | å³ä¸ |
| clear ã rehash ã reserve ã operator= | å§ç» |
| insert ã emplace ã emplace_hint ã operator[] | ä» è¥éåå¸å¯¼è´ |
| erase | ä» ä¸ºæå被æ¦é¤å ç´ è |
注æ
- swap 彿°ä¸éæ³å容å¨å çä»»ä½è¿ä»£å¨ï¼ä½å®ä»¬éæ³åæ 记交æ¢åºåç»å°¾çè¿ä»£å¨ã
- æååå¨äºå®¹å¨ä¸çå ³é®æå ç´ çå¼ç¨åæéä» å æ¦é¤è¯¥å ç´ æè¢«éæ³åï¼å³ä½¿å¨éæ³å对åºè¿ä»£å¨æ¶ã
æåç±»å
| Â | |
| æåç±»å | å®ä¹ |
key_type
|
Key |
mapped_type
|
T |
value_type
|
std::pair<const Key, T> |
size_type
|
æ ç¬¦å·æ´æ°ç±»åï¼éå¸¸æ¯ std::size_t ï¼ |
difference_type
|
æç¬¦å·æ´æ°ç±»åï¼éå¸¸æ¯ std::ptrdiff_t ï¼ |
hasher
|
Hash |
key_equal
|
KeyEqual |
allocator_type
|
Allocator |
reference
|
value_type& |
const_reference
|
const value_type& |
pointer
|
std::allocator_traits<Allocator>::pointer |
const_pointer
|
std::allocator_traits<Allocator>::const_pointer |
iterator
|
éçååè¿ä»£å¨ (LegacyForwardIterator) |
const_iterator
|
常ååè¿ä»£å¨ |
local_iterator
|
ç±»å«ãå¼ãå·®ãæéåå¼ç¨ç±»åé½ä¸ iterator ç¸åçè¿ä»£å¨ç±»åãè½ç¨æ¤è¿ä»£å¨å¨å个桶è¿ä»£ï¼ä½ä¸è½è·¨æ¡¶ã |
const_local_iterator
|
ç±»å«ãå¼ãå·®ãæéåå¼ç¨ç±»åé½ä¸ const_iterator ç¸åçè¿ä»£å¨ç±»åãè½ç¨æ¤è¿ä»£å¨å¨å个桶è¿ä»£ï¼ä½ä¸è½è·¨æ¡¶ã |
node_type(C++17 èµ·)
|
表示容å¨ç»ç¹çç»ç¹ææç¹å |
insert_return_type(C++17 èµ·)
|
æè¿°æå
¥ node_type ç»æçç±»åï¼ä¸åç±»åçç¹å template <class Iter, class NodeType> struct /*unspecified*/ { Iter position; bool inserted; NodeType node; }; iterator å node_type å®ä¾åã |
æå彿°
æé unordered_map (å ¬å¼æå彿°) | |
ææ unordered_map (å ¬å¼æå彿°) | |
| èµå¼ç»å®¹å¨ (å ¬å¼æå彿°) | |
| è¿åç¸å
³çåé
å¨ (å ¬å¼æå彿°) | |
è¿ä»£å¨ | |
| è¿åæå容å¨ç¬¬ä¸ä¸ªå
ç´ çè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæå容å¨å°¾ç«¯çè¿ä»£å¨ (å ¬å¼æå彿°) | |
容é | |
| æ£æ¥å®¹å¨æ¯å¦ä¸ºç©º (å ¬å¼æå彿°) | |
| è¿å容纳çå
ç´ æ° (å ¬å¼æå彿°) | |
| è¿åå¯å®¹çº³çæå¤§å
ç´ æ° (å ¬å¼æå彿°) | |
ä¿®æ¹å¨ | |
| æ¸
é¤å
容 (å ¬å¼æå彿°) | |
| æå
¥å
ç´ æç»ç¹ (C++17 èµ·) (å ¬å¼æå彿°) | |
| (C++17) |
æå
¥å
ç´ ï¼æè¥å
³é®å·²åå¨åèµå¼ç»å½åå
ç´ (å ¬å¼æå彿°) |
| å使é å
ç´ (å ¬å¼æå彿°) | |
| ä½¿ç¨æç¤ºå使é å
ç´ (å ¬å¼æå彿°) | |
| (C++17) |
è¥é®ä¸åå¨åå使å
¥ï¼è¥é®åå¨åä¸åä»»ä½äº (å ¬å¼æå彿°) |
| æ¦é¤å
ç´ (å ¬å¼æå彿°) | |
| 交æ¢å
容 (å ¬å¼æå彿°) | |
| (C++17) |
ä»å¦ä¸å®¹å¨éåºç»ç¹ (å ¬å¼æå彿°) |
| (C++17) |
ä»å¦ä¸å®¹å¨æ¥åç»ç¹ (å ¬å¼æå彿°) |
æ¥æ¾ | |
| è®¿é®æå®çå
ç´ ï¼åæ¶è¿è¡è¶çæ£æ¥ (å ¬å¼æå彿°) | |
| è®¿é®ææå
¥æå®çå
ç´ (å ¬å¼æå彿°) | |
| è¿åå¹é
ç¹å®é®çå
ç´ æ°é (å ¬å¼æå彿°) | |
| 寻æ¾å¸¦æç¹å®é®çå
ç´ (å ¬å¼æå彿°) | |
| (C++20) |
æ£æ¥å®¹å¨æ¯å¦å«æå¸¦ç¹å®å
³é®çå
ç´ (å ¬å¼æå彿°) |
| è¿åå¹é
ç¹å®é®çå
ç´ èå´ (å ¬å¼æå彿°) | |
æ¡¶æ¥å£ | |
| è¿åä¸ä¸ªè¿ä»£å¨ï¼æåæå®çæ¡¶çå¼å§ (å ¬å¼æå彿°) | |
| è¿åä¸ä¸ªè¿ä»£å¨ï¼æåæå®çæ¡¶çæ«å°¾ (å ¬å¼æå彿°) | |
| è¿åæ¡¶æ° (å ¬å¼æå彿°) | |
| è¿åæ¡¶çæå¤§æ°é (å ¬å¼æå彿°) | |
| è¿åå¨ç¹å®çæ¡¶ä¸çå
ç´ æ°é (å ¬å¼æå彿°) | |
| è¿å带æç¹å®é®çæ¡¶ (å ¬å¼æå彿°) | |
åå¸çç¥ | |
| è¿åæ¯ä¸ªæ¡¶çå¹³åå
ç´ æ°é (å ¬å¼æå彿°) | |
| ç®¡çæ¯ä¸ªæ¡¶çå¹³åå
ç´ æ°éçæå¤§å¼ (å ¬å¼æå彿°) | |
| 为è³å°ä¸ºæå®æ°éçæ¡¶é¢çåå¨ç©ºé´ã è¿ä¼éæ°çæåå¸è¡¨ã (å ¬å¼æå彿°) | |
| 为è³å°ä¸ºæå®æ°éçå
ç´ é¢çåå¨ç©ºé´ã è¿ä¼éæ°çæåå¸è¡¨ã (å ¬å¼æå彿°) | |
è§å¯å¨ | |
| è¿åç¨äºå¯¹å
³é®åå¸ç彿° (å ¬å¼æå彿°) | |
| è¿åç¨äºæ¯è¾é®çç¸çæ§ç彿° (å ¬å¼æå彿°) | |
éæå彿°
| (C++20 ä¸ç§»é¤) |
æ¯è¾ unordered_map ä¸çå¼ (彿°æ¨¡æ¿) |
| ç¹å std::swap ç®æ³ (彿°æ¨¡æ¿) | |
| (C++20) |
æ¦é¤æææ»¡è¶³ç¹å®å¤å«æ åçå
ç´ (彿°æ¨¡æ¿) |
æ¨å¯¼æå¼(C++17 èµ·)
示ä¾
#include <iostream> #include <string> #include <unordered_map>  int main() { // å建ä¸ä¸ª string ç unordered_map ï¼æ å°å° string ï¼ std::unordered_map<std::string, std::string> u = { {"RED","#FF0000"}, {"GREEN","#00FF00"}, {"BLUE","#0000FF"} };  // è¿ä»£å¹¶æå° unordered_map çå ³é®åå¼ for( const auto& n : u ) { std::cout << "Key:[" << n.first << "] Value:[" << n.second << "]\n"; }  // æ·»å æ°å ¥å£å° unordered_map u["BLACK"] = "#000000"; u["WHITE"] = "#FFFFFF";  // ç¨å ³é®è¾åºå¼ std::cout << "The HEX of color RED is:[" << u["RED"] << "]\n"; std::cout << "The HEX of color BLACK is:[" << u["BLACK"] << "]\n";  return 0; }
è¾åºï¼
Key:[RED] Value:[#FF0000] Key:[BLUE] Value:[#0000FF] Key:[GREEN] Value:[#00FF00] The HEX of color RED is:[#FF0000] The HEX of color BLACK is:[#000000]