begin()函数
原型: iterator begin();
const_iterator begin();
功能:返回一个当前vector容器中起始元素的迭代器。
end()函数
原型:iterator end();
const_iterator end();
功能:返回一个当前vector容器中末尾元素的迭代器。
front()函数
原型:reference front();
const_reference front();
功能:返回当前vector容器中起始元素的引用。
back()函数
原型:reference back();
const_reference back();
功能:返回当前vector容器中末尾元素的引用。
说明: 可用 * vector.begin() 或 * vector.end() 得到 vector 首尾的值。
也可用 vector.front() 、vector.back() 来得到 vector 首尾的值。
insert() 函数
insert() 函数有以下三种用法:
iterator insert( iterator loc, const TYPE &val );
在指定位置loc前插入值为val的元素,返回指向这个元素的迭代器。
void insert( iterator loc, size_type num, const TYPE &val );
在指定位置loc前插入num个值为val的元素。
void insert( iterator loc, input_iterator start, input_iterator end );
在指定位置loc前插入区间[start, end)的所有元素。
//创建一个vector,置入字母表的前十个字符
vector <char> alphaVector;
for (int i = 0; i < 10; i++)
alphaVector.push_back(i + 65);
//在vector开头插入C
vector <char>::iterator theIterator = alphaVector.begin();
alphaVector.insert(theIterator,'C');
//显示vector的内容
for (theIterator = alphaVector.begin(); theIterator != alphaVector.end(); theIterator++)
cout << *theIterator;
//这段代码将显示:CABCDEFGHIJ
push_back()函数
vector是用数组实现的,每次执行push_back操作,相当于底层的数组实现要重新分配大小(即先free掉原来的存储,后重新malloc)。
pop_back()函数
删除 vector 中最后一个元素(会改变 vector.size() 的大小)。
vector <int> v1;
vector <int>::iterator Iter;
v1.push_back(10);
v1.push_back(20);
v1.push_back(30);
v1.push_back(40);
v1.push_back(50);
cout << "v1 =";
for (Iter = v1.begin(); Iter != v1.end(); Iter++)
cout << " " << *Iter;
cout << endl;
v1.pop_back();
cout << "v1 =";
for (Iter = v1.begin(); Iter != v1.end(); Iter++)
cout << " " << *Iter;
cout << endl;
/*运行结果:
v1 = 10 20 30 40 50
v1 = 10 20 30 40
*/
erase()函数
从指定容器删除指定位置的元素或某段范围内的元素。
重载1:iterator erase( iterator _Where);
返回值是一个迭代器,指向删除元素下一个元素;
重载2:iterator erase( iterator _First, iterator _Last);
返回值也表示一个迭代器,指向最后一个删除元素的下一个元素;
//实例
vector <int> v1;
vector <int>::iterator Iter;
v1.push_back(10);
v1.push_back(20);
v1.push_back(30);
v1.push_back(40);
v1.push_back(50);
cout << "v1 =";
for (Iter = v1.begin(); Iter != v1.end(); Iter++)
cout << " " << *Iter;
cout << endl;
v1.erase(v1.begin());
cout << "v1 =";
for (Iter = v1.begin(); Iter != v1.end(); Iter++)
cout << " " << *Iter;
cout << endl;
v1.erase(v1.begin() + 1, v1.begin() + 3);
cout << "v1 =";
for (Iter = v1.begin(); Iter != v1.end(); Iter++)
cout << " " << *Iter;
cout << endl;*/
/*运行结果:
v1 = 10 20 30 40 50
v1 = 20 30 40 50
v1 = 20 50
*/
参考文章:C++ vector 的 begin()、end()、front()、back() 区别
[c++] vector中insert()的用法详解
vector::erase()方法的详细介绍及问题解答
resize()函数和reserve()函数
size(大小),vector中当前实际存储的元素个数。
capacity(容量),当前vector最多能使用的存储空间,大于等于size。
可用vector的size() 和 capacity() 方法获得该vector当前的size和capacity值。
vector的resize()和reserve()方法分别对size和capacity进行操作。
说明:
实现:
#include
#include
using namespace std;
int main(int argc, char** argv) {
vector<int> v(4,8);
v.reserve(10);
cout << v.size() << endl; // v的实际大小 4
cout << v.capacity() << endl; // v的容量大小 10
}
参考文章:vector的resize函数和reserve函数