首頁 > php教程 > PHP开发 > c++ STL標準容器之Iterator使用

c++ STL標準容器之Iterator使用

高洛峰
發布: 2016-12-13 17:33:52
原創
1278 人瀏覽過

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程式碼 

}
登入後複製

Crrrro c++除了iterator之外,還提供了const_iterator,後者只能讀取集合中的數據,但是不能改變其值.

 

3.java的迭代器貌似只能單步自增,而c++的迭代器除此之外,還可以實現算數操作,例如+n,-n,這樣對於需要隨機讀取某個元素的場景就就很有用了,但是,貌似只有vector的iterator才支援算數操作。也就是說前面例子中的迭代器it是不能進行 it = it+n之類的操作的。這一點要切記。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門推薦
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板