c++ STL标准容器之Iterator使用
程序员文章站
2022-04-13 16:26:24
...
C++ STL绝大多数标准容器都提供了Iterator,一些容器,比如priority_queue,因为语意上就不应该允许随便遍历容器中的元素,所以也就没有Iterator了。
23种经典设计模式中就有迭代器模式,java集合框架也实现了这个模式:
Java代码
package java.util; public interface Iterator<E> { boolean hasNext(); E next(); void remove(); }
c++的迭代器要比java更灵活,主要体现在:
1.java只有从前向后的一种迭代器,c++除了从前向后迭代器外,还提供了从后向前的迭代器,比如:
Cpp代码
map<int,int> amap; amap.insert(pair<int,int>(1,1)); amap.insert(pair<int.int>(2,2)); map<int,int>::iterator it; for(it = amap.begin();it != ampa.end();it++)//从前向后 { cout<<"key:"<<it->first<<" value:"<<it->second<<endl;
Cpp代码
}
Cpp代码
map<int,int>::reverse_iterator rit; for(rit = amap.rbegin();rit != amap.rend();rit++)//从后向前 { cout<<"key:"<<rit->first<<" value:"<<rit->second<<endl; }
2.c++除了iterator之外,还提供了const_iterator,后者只能读取集合中的数据,但是不能改变其值.
3.java的迭代器貌似只能单步自增,而c++的迭代器 除此之外,还可以实现算数操作,比如+n,-n,这样对于需要随机读取某个元素的场景就就很有用了,但是,貌似只有 vector的iterator才支持算数操作。也就是说前面例子中的迭代器it是不能进行 it = it+n之类的操作的。这一点要切记。
推荐阅读
-
C++程序员应了解的那些事(94)之STL容器内存释放问题
-
C++之标准模板库STL续(容器,算法)
-
C++之标准模板库STL
-
Go标准容器之Ring的使用说明
-
c/c++ 标准顺序容器 之 push_back,push_front,insert,emplace 操作
-
C++ STL容器详解之红黑树部分模拟实现
-
C++ 标准模板库 STL 顺序容器详解
-
C++:[STL]详解STL之sequence container的操作及使用(vector)
-
C++的面向对象和泛型编程思想——STL(标准模板库)常用容器之stack、queue容器(栈与队列)
-
c++ STL标准容器之Iterator使用