迭代器是一種設計模式,它是一個對象,它能夠遍歷並選擇序列中的對象,而開發人員不須要了解該序列的底層結構。迭代器一般被稱爲「輕量級」對象,由於建立它的代價小。java
Java中的Iterator功能比較簡單,而且只能單向移動:算法
(1) 使用方法iterator()要求容器返回一個Iterator。第一次調用Iterator的next()方法時,它返回序列的第一個元素。注意:iterator()方法是java.lang.Iterable接口,被Collection繼承。設計模式
(2) 使用next()得到序列中的下一個元素。數組
(3) 使用hasNext()檢查序列中是否還有元素。數據結構
(4) 使用remove()將迭代器新返回的元素刪除。spa
Iterator是Java迭代器最簡單的實現,爲List設計的ListIterator具備更多的功能,它能夠從兩個方向遍歷List,也能夠從List中插入和刪除元素。.net
1 迭代器應用: 2 list l = new ArrayList(); 3 l.add("aa"); 4 l.add("bb"); 5 l.add("cc"); 6 for (Iterator iter = l.iterator(); iter.hasNext();) { 7 String str = (String)iter.next(); 8 System.out.println(str); 9 } 10 /*迭代器用於while循環 11 Iterator iter = l.iterator(); 12 while(iter.hasNext()){ 13 String str = (String) iter.next(); 14 System.out.println(str); 15 } 16 */
1.Iterator設計
Java提供一個專門的迭代器<<interface>>Iterator,咱們能夠對某個序列實現該interface,來提供標準的Java迭代器。Iterator接口實現後的功能是「使用」一個迭代器.code
2.Iterable對象
Java中還提供了一個Iterable接口,Iterable接口實現後的功能是「返回」一個迭代器,咱們經常使用的實現了該接口的子接口有: Collection<E>, Deque<E>, List<E>, Queue<E>, Set<E> 等.該接口的iterator()方法返回一個標準的Iterator實現。實現這個接口容許對象成爲 Foreach 語句的目標。就能夠經過Foreach語法遍歷你的底層序列。
Iterable接口包含一個可以產生Iterator的iterator()方法,而且Iterable接口被foreach用來在序列中移動。所以若是建立了任何實現Iterable接口的類,均可以將它用於foreach語句中。
3 Iterator與泛型搭配
Iterator對集合類中的任何一個實現類,均可以返回這樣一個Iterator對象。能夠適用於任何一個類。
由於集合類(List和Set等)能夠裝入的對象的類型是不肯定的,從集合中取出時都是Object類型,用時都須要進行強制轉化,這樣會很麻煩,用上泛型,就是提早告訴集合肯定要裝入集合的類型,這樣就能夠直接使用而不用顯示類型轉換.很是方便.
4.foreach和Iterator的關係
for each是jdk5.0新增長的一個循環結構,能夠用來處理集合中的每一個元素而不用考慮集合定下標。
格式以下
for(variable:collection){ statement; }
定義一個變量用於暫存集合中的每個元素,並執行相應的語句(塊)。collection必須是一個數組或者是一個實現了lterable接口的類對象。
能夠看出,使用for each循環語句的優點在於更加簡潔,更不容易出錯,沒必要關心下標的起始值和終止值。
forEach不是關鍵字,關鍵字仍是for,語句是由iterator實現的,他們最大的不一樣之處就在於remove()方法上。
通常調用刪除和添加方法都是具體集合的方法,例如:
List list = new ArrayList(); list.add(...); list.remove(...);
可是,若是在循環的過程當中調用集合的remove()方法,就會致使循環出錯,由於循環過程當中list.size()的大小變化了,就致使了錯誤。 因此,若是想在循環語句中刪除集合中的某個元素,就要用迭代器iterator的remove()方法,由於它的remove()方法不只會刪除元素,還會維護一個標誌,用來記錄目前是否是可刪除狀態,例如,你不能連續兩次調用它的remove()方法,調用以前至少有一次next()方法的調用。
forEach就是爲了讓用iterator循環訪問的形式簡單,寫起來更方便。固然功能不太全,因此但若有刪除操做,仍是要用它原來的形式。
4 使用for循環與使用迭代器iterator的對比
效率上的各有有事
採用ArrayList對隨機訪問比較快,而for循環中的get()方法,採用的便是隨機訪問的方法,所以在ArrayList裏,for循環較快
採用LinkedList則是順序訪問比較快,iterator中的next()方法,採用的便是順序訪問的方法,所以在LinkedList裏,使用iterator較快
從數據結構角度分析,for循環適合訪問順序結構,能夠根據下標快速獲取指定元素.而Iterator 適合訪問鏈式結構,由於迭代器是經過next()和Pre()來定位的.能夠訪問沒有順序的集合.