关于 迭代器 的看法

1. 如何获取一个迭代器(iterator)

2. 迭代器本身能够执行什么操作

3. 哪些表 ADT 方法需要迭代器作为参数


iterator begin():  返回一个适当的迭代器,表示容器中的第一项

iterator end(): 返回一个适当的迭代器,表示容器的尾端(终端)标记(即容器中最后一项之后的位置)

end  方法有些不同寻常,因为它返回一个“越界”的迭代器


迭代器可以用!=和==进行比较,

itr++ 和 ++itr :将迭代器推进到下一个位置。

前缀形式和后缀形式都可以使用的。

*itr :返回对存储在迭代器 itr 的位置上对象的引用。

所返回的引用可以允许修改,也可以不允许修改。

itr1 = itr2 :若 itr1 和 itr2 指向同一个位置则返回 true ,否则返回 false。

itr1 !=itr2 :若 itr1 和 itr2 指向不同的位置则返回 true ,否则返回 false。


 iterator insert (iterator pos,const object &x): 把 x 添加到表中由迭代器 pos 所给定的位置之前的位置上。

这是对 list (但不是对 vector )的常数时间的操作。返回值是指向被插入项的位置的一个迭代器。

iterator erase (iterator pos) : 删除由迭代器所给定的位置上的对象。这是对 list (但不是对 vector )的常数时间的操作。返回值是调用之前 pos 的后继元素所在的位置。

该操作使 pos 失效,现在它是多余的了,因为它正在指向的容器项已经被删除。

iterator erase (iterator start,iterator end): 删除从位置 start 开始直到(但不包括)位置 end ,为止的所有的项。

注意:整个表可以通过调用 c.erase(c.begin(),c.end()) 而被删除。


 

上一篇:STL模板库


下一篇:[leetcode 10-05] 一、顶端迭代器 -- 每日一题(获取顶端元素,但指针不发生变化)