vector容器被称为动态数组,也被称为向量。它与array容器的区别是:array是静态数组。
动态扩展:并不是在原空间之后续接新空间,而是找更大的内存空间,然后将原数据拷贝新空间,释放原空间
at()函数:返回对矢量中指定位置的元素的引用
pop_back()删除数组末尾的元素
push_back()函数:在数组末尾添加元素
back()函数:返回对向量中最后一个元素的引用。
front()函数:返回对向量中第一个元素的引用。
begin()函数:返回第一个元素的地址。
end()函数:返回最后一个元素的下一个地址。
capacity()函数:返回在不分配更多的存储的情况下向量可以包含的元素数。
clear()函数: 清除向量的元素。
size()函数:向量的当前长度
swap()函数:交换两个向量元素
empty()函数:判断数组是否为空
erase()函数:从指定位置删除向量中的一个元素或一系列元素
insert()函数:将元素或许多元素或一系列元素插入到指定位置的向量中。
position
向量中插入第一个元素的位置。
value
插入到向量中的元素的值。
count
插入向量中的元素数目。
first
要复制的范围元素中的第一个元素的位置。
last
要复制的元素范围以外的第一个元素的位置。
返回值
前两个 insert 函数返回一个指定新元素插入到向量的位置的迭代器。
iterator insert(
const_iterator position,
const Type& value);
iterator insert(
const_iterator position,
Type&& value);
void insert(
const_iterator position,
size_type count,
const Type& value);
template <class InputIterator>
void insert(
const_iterator position,
InputIterator first,
InputIterator last);
operator!=运算符:
operator<运算符:测试运算符左侧的对象是否小于右侧的对象。
operator<=运算符:测试运算符左侧的对象是否小于或等于右侧的对象。
operator==运算符:测试运算符左侧的对象是否等于右侧的对象。
operator>运算符:测试运算符左侧的对象是否大于右侧的对象。
operator>=运算符:测试运算符左侧的对象是否大于或等于右侧的对象。
vector容器与arrayr容器嵌套:
vector构造函数:
vector<T> v;//采用模板实现类实现,默认构造函数
vector(v.begin(),v.end());//将v[begin(),end())区间中的元素拷贝给本身
vector(n,elem);//构造函数将n个elem拷贝给本身
vector(const vector& vec);//拷贝构造函数
vector赋值操作:
函数原型:
vector& operator=(const vector& vec);//重载等号运算符
assign(beg,end);//将[beg,end)区间数据拷贝赋值给本身
assign(n,elem);//将n个elem拷贝赋值给本身
vector容器resize(int num)函数:
重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除
(重载版本resize(int num,elem)):
重新指定容器的长度为num,若容器变长,则以elem填充新位置。如果容器变短,则末尾超出容器长度的元素被删除
vector容器reserve(int len)函数:减少vector在动态扩展容器时的扩展次数。
容器预留len个元素长度,预留位置不初始化,元素不可访问