std::vector
来自cppreference.com
在头文件 <vector> 中定义
|
||
template< class T, |
||
std::vector
是一种序列容器,是对大小可变数组封装。
数组中的元素是连续存储的,所以除了能够通过迭代器访问外,还可以通过常规的指针偏移量访问元素。换句话说,可以将指向 vector 元素的指针传入以指向数组元素的指针作为参数的函数。
vector 会在需要时自动调整所占内存的大小。与对应的静态数组相比,vector 所占的内存通常要更多,因为它还分配了额外的内存以应对将来可能的扩张。于是,vector 就不必在每次插入元素时都重新分配一次内存了,除非这块预留的内存用尽。已分配内存的总大小可以通过 capacity()
函数查询。所占的额外的内存可以通过调用 shrink_to_fit()
返还给系统。
从性能方面考虑,内存重分配操作的代价通常很大。如果事先知道元素个数,可以使用 reserve()
函数消除重新分配操作。
针对 vector 的各种常见操作的复杂度(效率)如下:
- 随机访问 - 常数 O(1)
- 在尾部增删元素 - 摊余(amortized)常数 O(1)}}
- 增删元素 - 至 vector 尾部的线性距离 O(n)}}
std::vector
满足 Container
、AllocatorAwareContainer
、SequenceContainer
和 ReversibleContainer
的要求。
目录 |
[编辑] 特化
标准库为 bool 类型提供了特化版本的 std::vector
,优化了空间利用率。
节省空间的动态bitset (类模板) |
[编辑] 成员类型
成员类型 | 定义 |
value_type
|
T
|
allocator_type
|
Allocator
|
size_type
|
无符号整数类型(通常是size_t)
原文: Unsigned integral type (usually size_t) |
difference_type
|
有符号整型(通常是ptrdiff_t) |
reference
|
Allocator::reference (至 C++11)value_type& (C++11 起)
|
const_reference
|
Allocator::const_reference (至 C++11)const value_type& (C++11 起)
|
pointer
|
Allocator::pointer (至 C++11)std::allocator_traits<Allocator>::pointer (C++11 起) |
const_pointer
|
Allocator::const_pointer (至 C++11) std::allocator_traits<Allocator>::const_pointer (C++11 起) |
iterator
|
RandomAccessIterator
|
const_iterator
|
随机访问常迭代器 |
reverse_iterator
|
std::reverse_iterator<iterator> |
const_reverse_iterator
|
std::reverse_iterator<const_iterator> |
[编辑] 成员函数
构建 vector (公共成员函数) | |
析构 vector (公共成员函数) | |
将值分配到容器中 (公共成员函数) | |
将值分配到容器中 (公共成员函数) | |
返回的关联分配器 (公共成员函数) | |
元素访问 | |
访问指定的元素,同时进行越界检查 (公共成员函数) | |
访问指定的元素 (公共成员函数) | |
访问第一个元素 (公共成员函数) | |
访问最后一个元素 (公共成员函数) | |
返回指向内存中数组第一个元素的指针 (公共成员函数) | |
迭代器 | |
返回指向容器开始的迭代器 (公共成员函数) | |
返回指向容器尾端的迭代器 (公共成员函数) | |
返回一个指向容器最后一个元素的反向迭代器 (公共成员函数) | |
返回一个指向容器前端的反向迭代器 (公共成员函数) | |
容量 | |
检查是否容器是空的 原文: checks whether the container is empty (公共成员函数) | |
返回的元素数 (公共成员函数) | |
返回可能容纳的最大元素数 (公共成员函数) | |
储备存储 (公共成员函数) | |
返回的元素的数目,可以保持在当前分配的存储空间 原文: returns the number of elements that can be held in currently allocated storage (公共成员函数) | |
(C++11) |
通过释放未使用的内存减少了内存的使用情况 原文: reduces memory usage by freeing unused memory (公共成员函数) |
| |
清除其内容 (公共成员函数) | |
插入元素 (公共成员函数) | |
(C++11) |
就地构造元素 (公共成员函数) |
擦除元素 (公共成员函数) | |
将元素添加到末端 (公共成员函数) | |
(C++11) |
在末端就地构造元素 (公共成员函数) |
删除最后一个元素 (公共成员函数) | |
改变容器中可存储元素的个数 (公共成员函数) | |
交换vector 的内容 (公共成员函数) |
[编辑] 非成员函数
根据字典顺序比较的vector中的值 原文: lexicographically compares the values in the vector (函数模板) | |
特化std::swap算法 (函数模板) |