六大部件
data:image/s3,"s3://crabby-images/efe47/efe47636400743d4ce432b22f58c19cff699e31a" alt="stl_items.png"
分配器:为容器分配内存
迭代器:算法只能通过迭代器访问容器
容器
data:image/s3,"s3://crabby-images/d2b56/d2b56fb84bc3e7b66613fc8e5f067033358ab688" alt="stl.png"
Array
定长数组
_M_instance:指向数组首元素的指针(int a[10]的a)
data:image/s3,"s3://crabby-images/ccaeb/ccaeb976560972f21a2ae456bcca87b14f5789a3" alt="array_overview.png"
iterator为指针,traits通过指针特化处理
data:image/s3,"s3://crabby-images/d1ca2/d1ca293239730b9e5430d64ebd55e532d870130e" alt="array.png"
Vector
变长数组
start(4B):指向第一个元素的指针
finish(4B):指向最后一个元素的下一个指针
end_of_storage(4B):容器申请的内存空间的最后一个元素的下一个地址
若内存空间不够则申请当前空间两倍的空间
data:image/s3,"s3://crabby-images/f2e8b/f2e8b47926e0c158213fc2d159ad8f620ef1a4e9" alt="vector_overview.png"
iterator为指针,traits通过指针特化处理
data:image/s3,"s3://crabby-images/c838d/c838d92ff0b4dd596507d2d64e57a6f723bc9c44" alt="vector_iterator.png"
List
双向链表
node(4B):指向头节点的指针
data:image/s3,"s3://crabby-images/b6e3b/b6e3b107ab40f25fe0ebbe5c297247d3efddbbdb" alt="list_overview.png"
iterator里的node为指向当前节点的指针
data:image/s3,"s3://crabby-images/0c20b/0c20bc4550d67ad7a31d0d7a98f024eecdbb7502" alt="list_iterator.png"
Forward List
单向链表
data:image/s3,"s3://crabby-images/a7239/a72398f554f6e647dd1e6ff2e531999fcfabdf0e" alt="forward_list.png"
Deque
双端队列
queue在内存中每个buffer块离散存储,通过map表记录各buffer块的地址
start(16B):指向首元素的iterator
finish(16B):指向尾巴元素下一个块的iterator
map(4B):指向map首元素的指针
map_size:map占用内存的大小
data:image/s3,"s3://crabby-images/5191f/5191f779926e9c62335c7aa27a3675e1e3e900f4" alt="deque_overview.png"
cur:指向当前元素的指针
first:指向当前buffer块首元素的指针
last:指向当前buffer块尾元素下一个块的指针
node:指向map对应元素的指针
data:image/s3,"s3://crabby-images/08c13/08c13868d938bc588b9cdc6c2f3943e62e858761" alt="deque_iterator.png"
Queue
队列
不允许遍历也不提供iterator
可选择list或deque作为底层存储
不可选择vector作为底层存储
data:image/s3,"s3://crabby-images/f1b39/f1b398d1d5fd7283608418be90c1e8ebf10676c6" alt="queue.png"
Stack
栈
不允许遍历也不提供iterator
可选择list或deque或vector作为底层存储
data:image/s3,"s3://crabby-images/5f384/5f384188c5c0c9d790797e8cdca3efca44a414b0" alt="stack.png"
Set
集合
t:红黑树
data:image/s3,"s3://crabby-images/c2c89/c2c89c01f93b41dd5eabab8c58936173e1710107" alt="set.png"
集合 | 底层实现 | 是否有序 | 数值是否可以重复 | 能否更改数值 | 查询效率 | 增删效率 |
---|---|---|---|---|---|---|
std::set | 红黑树 | 有序 | 否 | 否 | O(log n) | O(log n) |
std::multiset | 红黑树 | 有序 | 是 | 否 | O(logn) | O(logn) |
std::unordered_set | 哈希表 | 无序 | 否 | 否 | O(1) | O(1) |
std::unordered_set底层实现为哈希表,std::set 和std::multiset 的底层实现是红黑树,红黑树是一种平衡二叉搜索树,所以key值是有序的,但key不可以修改,改动key值会导致整棵树的错乱,所以只能删除和增加
Map
键值对集合
t:红黑树
data:image/s3,"s3://crabby-images/4a6c7/4a6c76754b2a403826e04ed2dd3687f08931a351" alt="map.png"
映射 | 底层实现 | 是否有序 | 数值是否可以重复 | 能否更改数值 | 查询效率 | 增删效率 |
---|---|---|---|---|---|---|
std::map | 红黑树 | key有序 | key不可重复 | key不可修改 | O(logn) | O(logn) |
std::multimap | 红黑树 | key有序 | key可重复 | key不可修改 | O(log n) | O(log n) |
std::unordered_map | 哈希表 | key无序 | key不可重复 | key不可修改 | O(1) | O(1) |
std::unordered_map 底层实现为哈希表,std::map 和std::multimap 的底层实现是红黑树。同理,std::map 和std::multimap 的key也是有序的
Functors
Iterator Traits
由于算法需要得到iterator的某些属性,对于非指针iterator的结构包含属性,但对于指针类型无法获取。通过iterator traits对于iterator处理