vector与iterator
程序员文章站
2022-07-12 14:51:53
...
vector优先级几乎总是在数组之上
动态数组,大小可随时增减
#include<vector>
声明与初始化
vector<string>str1(int size,string s1);
1.括号可以省略,即没有初始值
size即初始长度(后面不够会自动加),s1是初始值,只能有一个,即所有的
元素都与之相等
2.括号里面只写一个与之同类型的vector,即生成一个复制品
iterator声明: 容器名<数据类型>::iterator 名称
vector<string>::iterator myit;//普通iterator
vector<string>::const_iterator myit;//常量iterator,指向的元素无法通
过该iterator改变
iterator类似于指针,指向指定的容器中的元素
vector方法:
str1.push_back();//在最末尾添加一个元素
str1.pop_back();//删除最后一个元素
str1.clear();//清空数组
str1.size();//长度
str1.capacity();//容量
str1.reserve()//把容量扩展至给定参数大小
str1.empty();//判断是否为空
str2.begin();//返回一个指向开始元素的iterator
str2.end();//返回一个指向末尾之后(不是末尾)的iterator
str2.insert();//参数为iterator(插入位置)+插入元素
//eg:str2.insert((str2.begin()+2),"asce")在第三个元素处插入新元素
str2.erase();//删除指定iterator指向元素
//eg:str2.erase((str2.begin()+2));//删除下标为2的元素
c++11新特性 emplact_back()
效果等于push_back但更高效 emplact_back只调用了转移构造函数
push_back首先会调用构造函数构造这个临时对象,然后需要调用拷贝构造函数将这个临时对象放入容器中。原来的临时变量释放
只能用push_back添加新元素,不能写str1[0]="***";
容器配合迭代器使用实例
for (myit = str2.begin(); myit != str2.end(); myit++)
{
cout << *myit <<" ";
}//就把iterator当做指针运用就可以了
下一篇: vector容器的动态分配空间