迭代器是c++中用得比较多的一种访问机制。它定义了所有标准库容器以及vector、string等类型的迭代。
1、begin和end的使用:begin负责返回第一个元素的迭代器,end则返回容器最后一个元素的下一个位置,而不是最后一个元素,所以如果对于end指向进行取值运算c++中任何是非法的。它只作为一个标识,用于判断是否遍历完了整个容器。这里我们用v.begin()==v.end()来判断是否遍历完成。
2、如果容器里面放的是基本类型,那么我们可以用”*iter“,进行解应用,返回这个元素对应的数据;如果放的是复杂类型,比如struct,class这些用户自定义类型的话,我们可以用“iter->mem"来解引用。具体看代码:
<span style="font-size:18px;">int _tmain(int argc, _TCHAR* argv[])
{
struct MyStruct
{
int id = 0;
string name = "";
};
MyStruct m1, m2, m3;
m1.id = 1;
m1.name = "zhangsan1";
m2.id = 3;
m2.name = "zhangsan3";
m3.id = 4;
m3.name = "zhangsan4";
vector<MyStruct> mVector = { m1, m2, m3 };
// vector<string> mVector = { "ts1", "ts2", "ts3" };
// string mVector = "huangshihuan";
auto index = mVector.begin();
for (index; index != mVector.end(); index++)
{
cout << index->name << endl;
}
system("pause");
return 0;
}</span>
3、注意的问题,某些vector对象的操作会导致迭代器失效,比如push_back的操作。这里主要是指在迭代过程中对vector的操作,如果是迭代之前或者迭代之后就不会影响迭代器的使用。所以,在迭代的过程是绝对不允许对vector对象做push_back等操作的。比如下面的代码则是会带来报错的。
vector<string> mVector = { "ts1", "ts2", "ts3" };
auto index = mVector.begin();
for (index; index != mVector.end(); index++)
{
cout << *index << endl;
mVector.push_back("ts4");
}