C++之STL--初识vector
我们之前学习过静态数组的内容,静态数组的缺点在于一旦初始化之后,数组大小便无法改变,但是动态数组不存在这个问题.动态数组(vector容器)在需要扩展大小的时候,会自动处理它自己的存储需求.也就是说vector容器会根据添加的元素自动调正自身的大小.
要使用vector容器,需要声明头文件#include<vector>
vector使用格式vector<typename> variable
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<int> vec;
int i = 0;
cout << "vector_size:" << vec.size() << endl;
for (i; i < 6; i++) {
vec.push_back(i + 1);
}
cout << "vector_expand_num:" << vec.size() << endl;
for (i; i >= 0; i--) {
cout << "get_vec_value:" << vec[i] << endl;
}
vector<int>::iterator v = vec.begin();
while (v != vec.end()) {
cout << "v_value:" << *v << endl;
v++;
}
return 0;
}
输出:
vector_size:0
vector_expand_num:6
get_vec_value:17367376
get_vec_value:6
get_vec_value:5
get_vec_value:4
get_vec_value:3
get_vec_value:2
get_vec_value:1
v_value:1
v_value:2
v_value:3
v_value:4
v_value:5
v_value:6
push_back()
:在容器尾部添加数据
vector.size()
:获取容器大小
vector.begin()
:指向容器头部的迭代器
vector.end()
:指向容器尾部的迭代器
再来看字符串的用法
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<string> str;
str.push_back("www");
str.push_back(".baidu");
str.push_back(".com");
for (vector<string>::iterator iter = str.begin(); iter != str.end(); ++iter) {
cout << *iter;
}
return 0;
}
输出:
www.baidu.com
函数 | 介绍 |
---|---|
at(idx) | 传回索引idx所指的数据,如果idx越界,抛出out_of_range。 |
back() | 返回最后一个元素,不检查这个数据是否存在。 |
front() | 返回第一个元素。 |
swap() | 交换两个Vector。 |
pop_back() | 它从向量中删除最后一个元素。 |
empty() | 判断Vector是否为空(返回true时为空) |
insert() | 它将在指定位置插入新元素。 |
erase() | 删除指定的元素。 |
resize() | 它修改向量的大小。 |
clear() | 它从向量中删除所有元素。 |
size() | 返回Vector元素数量的大小。 |
str.erase(str.begin() + 1);//删除下标为1的元素
str.insert(str.begin() + 2, "123");//在下标为2的位置插入元素
str.pop_back();//删除尾部的元素
str.resize(10);//改变容器的大小
str.at(0);//返回下标为0的元素
str.back();//返回尾部元素
str.front();//返回头部元素