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::priority_queue
- std::span
- std::forward_list
- std::deque
- std::list
- std::set
- std::set<Key,Compare,Allocator>::insert
- std::set<Key,Compare,Allocator>::erase
- std::set<Key,Compare,Allocator>::end, std::set<Key,Compare,Allocator>::cend
- std::set<Key,Compare,Allocator>::set
- std::set<Key,Compare,Allocator>::~set
- std::set<Key,Compare,Allocator>::operator=
- std::set<Key,Compare,Allocator>::empty
- 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::set
std::set
  class Key,
  class Compare = std::less<Key>,
  class Allocator = std::allocator<Key>
  template <class Key, class Compare = std::less<Key>>
  using set = std::set<Key, Compare, std::pmr::polymorphic_allocator<Key>>;
std::set æ¯å
³è容å¨ï¼å«æ Key ç±»å对象çå·²æåºéãç¨æ¯è¾å½æ° æ¯è¾ (Compare) è¿è¡æåºãæç´¢ãç§»é¤åæå
¥æ¥æå¯¹æ°å¤æåº¦ã set éå¸¸ä»¥çº¢é»æ å®ç°ã
卿¯ä¸ªæ ååºä½¿ç¨æ¯è¾ (Compare) æ¦å¿µçåºæï¼ç¨çä»·å
³ç³»ç¡®å®å¯ä¸æ§ãä¸ç²¾ç¡®å°è¯´ï¼è¥äºä¸ªå¯¹è±¡ a ä¸ b ç¸äºé´æ¢ä¸æ¯è¾å¤§äºäº¦ä¸æ¯è¾å°äºï¼ !comp(a, b) && !comp(b, a) ï¼å认为å®ä»¬çä»·ã
std::set æ»¡è¶³å®¹å¨ (Container) ãå
·åé
å¨å®¹å¨ (AllocatorAwareContainer) ãå
³èå®¹å¨ (AssociativeContainer) åå¯éå®¹å¨ (ReversibleContainer) çè¦æ±ã
æåç±»å
| Â | |||||
| æåç±»å | å®ä¹ | ||||
key_type
|
Key | ||||
value_type
|
Key | ||||
size_type
|
æ ç¬¦å·æ´æ°ç±»åï¼éå¸¸æ¯ std::size_t ï¼ | ||||
difference_type
|
æç¬¦å·æ´æ°ç±»åï¼éå¸¸æ¯ std::ptrdiff_t ï¼ | ||||
key_compare
|
Compare | ||||
value_compare
|
Compare | ||||
allocator_type
|
Allocator | ||||
reference
|
| ||||
const_reference
|
| ||||
pointer
|
| ||||
const_pointer
|
| ||||
iterator
|
常éçååè¿ä»£å¨ (LegacyBidirectionalIterator) | ||||
const_iterator
|
常ååè¿ä»£å¨ | ||||
reverse_iterator
|
std::reverse_iterator<iterator> | ||||
const_reverse_iterator
|
std::reverse_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 å®ä¾åã | ||||
æå彿°
æé set (å ¬å¼æå彿°) | |
ææ set (å ¬å¼æå彿°) | |
| èµå¼ç»å®¹å¨ (å ¬å¼æå彿°) | |
| è¿åç¸å
³çåé
å¨ (å ¬å¼æå彿°) | |
è¿ä»£å¨ | |
| è¿åæå容å¨ç¬¬ä¸ä¸ªå
ç´ çè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæå容å¨å°¾ç«¯çè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæå容卿åå
ç´ çéåè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæåå端çéåè¿ä»£å¨ (å ¬å¼æå彿°) | |
容é | |
| æ£æ¥å®¹å¨æ¯å¦ä¸ºç©º (å ¬å¼æå彿°) | |
| è¿å容纳çå
ç´ æ° (å ¬å¼æå彿°) | |
| è¿åå¯å®¹çº³çæå¤§å
ç´ æ° (å ¬å¼æå彿°) | |
ä¿®æ¹å¨ | |
| æ¸
é¤å
容 (å ¬å¼æå彿°) | |
| æå
¥å
ç´ æç»ç¹ (C++17 èµ·) (å ¬å¼æå彿°) | |
| (C++11) |
å使é å
ç´ (å ¬å¼æå彿°) |
| (C++11) |
ä½¿ç¨æç¤ºå使é å
ç´ (å ¬å¼æå彿°) |
| æ¦é¤å
ç´ (å ¬å¼æå彿°) | |
| 交æ¢å
容 (å ¬å¼æå彿°) | |
| (C++17) |
ä»å¦ä¸å®¹å¨éåºç»ç¹ (å ¬å¼æå彿°) |
| (C++17) |
ä»å¦ä¸å®¹å¨æ¥åç»ç¹ (å ¬å¼æå彿°) |
æ¥æ¾ | |
| è¿åå¹é
ç¹å®é®çå
ç´ æ°é (å ¬å¼æå彿°) | |
| 寻æ¾å¸¦æç¹å®é®çå
ç´ (å ¬å¼æå彿°) | |
| (C++20) |
æ£æ¥å®¹å¨æ¯å¦å«æå¸¦ç¹å®å
³é®çå
ç´ (å ¬å¼æå彿°) |
| è¿åå¹é
ç¹å®é®çå
ç´ èå´ (å ¬å¼æå彿°) | |
| è¿åæåé¦ä¸ªä¸å°äºç»å®é®çå
ç´ çè¿ä»£å¨ (å ¬å¼æå彿°) | |
| è¿åæåé¦ä¸ªå¤§äºç»å®é®çå
ç´ çè¿ä»£å¨ (å ¬å¼æå彿°) | |
è§å¯å¨ | |
| è¿åç¨äºæ¯è¾é®ç彿° (å ¬å¼æå彿°) | |
| è¿åç¨äºå¨value_typeç±»åçå¯¹è±¡ä¸æ¯è¾é®ç彿°ã (å ¬å¼æå彿°) | |
éæå彿°
| (C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20 ä¸ç§»é¤)(C++20) |
æç
§åå
¸é¡ºåºæ¯è¾ set ä¸çå¼ (彿°æ¨¡æ¿) |
| ç¹å std::swap ç®æ³ (彿°æ¨¡æ¿) | |
| (C++20) |
æ¦é¤æææ»¡è¶³ç¹å®å¤å«æ åçå
ç´ (彿°æ¨¡æ¿) |
æ¨å¯¼æå¼(C++17 èµ·)
注æ
æåç±»å iterator ä¸ const_iterator å¯è½æ¯åä¸ç±»åçå«åãè¿è¡¨æä»¥äºä¸ªç±»åä¸ºåæ°ç±»åçä¸å¯¹å½æ°éè½½å¯è½è¿èåä¸å®ä¹è§åãå 为 iterator å¯è½¬æ¢ä¸º const_iterator ï¼å个以 const_iterator ä¸ºåæ°ç±»åç彿°ä¼æ¯ææçã
ç¼ºé·æ¥å
ä¸åæ´æ¹è¡ä¸ºçç¼ºé·æ¥å追溯å°åºç¨äºä»¥ååºçç C++ æ åã
| DR | åºç¨äº | åºçæ¶çè¡ä¸º | æ£ç¡®è¡ä¸º |
|---|---|---|---|
| LWG 103 | C++98 | è¿ä»£å¨å 许修æ¹å ³é® | 使è¿ä»£å¨ä¸ºå¸¸ |