Java中迭代器Iterator的使用Collection介面(list和set)和Map介面中
Java集合類中Map介面下的相關類並沒有像Collection介面的相關類一樣實現get()方法,因此在要實現遍歷輸出的場景中沒法直接用get()方法來取得物件中的資料,但Java本身提供了另一種遍歷資料的方法,即用Iterator迭代器,雖然Iterator可以用來遍歷讀取資料,但它本質上不是一種方法,它只是一種設計模式,它是一個物件,一個“輕量級”的物件。下文講講Iterator在不同介面中的使用方法:
(一)Iterator在Collection介面中的使用。
雖然Collection介面的相關類實現了get()方法,但將Iterator用在它們身上仍然是合適的,下面以ArrayList為例,討論Iterator在Collection中的兩中使用方法:
1.配合while()迴圈實現遍歷輸出:
1 ArrayList list = new ArrayList(); 2 //此處省略list的具體賦值過程 3 Iterator it = list.iterator(); 4 while(it.hasNext()){ 5 System.out.println(it.next()); 6 }
while()中的判斷條件it.hasNext()用於判斷it中是否還有下一元素,有的話就繼續迴圈,輸出語句中的it.next()既可以使“指標”往後走一位,又能將當前的元素返回,用於輸出。
2.配合for()迴圈實現遍歷輸出:
1 ArrayList list = new ArrayList(); 2 //此處省略list的賦值過程 3 for(Iterator it = list.iterator();it.hasNext();){ 4 System.out.println(it.next()); 5 }
for()迴圈中的使用原理跟while()是一樣的,在此就不再過多贅述。
不過上面的是在一般for()迴圈中的使用,我們還可以用for each 迴圈來代替Iterator,因為for each 本身就相當於一個迭代器了:
1 ArrayList list = new ArrayList(); 2 //此處同樣省略list的賦值過程 3 for(Object array:list){ 4 System.out.println(array); 5 }
需要注意的是for each 不適合用來增刪元素,如果單純用來遍歷元素,這種寫法也許會更簡潔一點。
(二)Iterator在Map介面中的使用:
下文用HashMap為例,討論迭代器的兩種主要使用方法。
1.與while()的結合
1 HashMap<K,V> myMap = new HashMap<K,V>();
2 //省略myMap的的賦值過程 myMap.entrySet()返回的是返回此對映中包含的對映關係的 Set
檢視;但是隻有set本事一部分功能
3 Iterator<Map.Entry<K,V> it=myMap.entrySet().iterator();
4 while(it.hasNext()){
5 System.out.println(it.next());
6 } 7 8 //如果想讓輸出更加格式化,可以自己重寫toString()方法,由於toString方法的重寫不是本文討論的重點,所以暫且不討論。
Map介面下的iterator應用方法與Collection中的略微有些不同,用到了entrySet()方法,entrySet()用來返回整個鍵—值對。
2.與for()的結合
1 HashMap<K,V> myMap=new HashMap<K,V>(); 2 //省略myMap的賦值過程 3 for(Iterator<Map.Entry<K,V>> it=myMap.entrySet().iterator();it.hasNext();){ 4 System.out.println(it.next()); 5 }
有上面幾個例子的說明,這裡就不用繼續解釋原理了。
同樣這裡再貼出for each代替Iterator的用法:
1 HashMap<K,V> myMap=new HashMap<K,V>(); 2 //省略myMap賦值過程 3 for(Object oj:myMap.entrySet()){ 4 System.out.println(oj); 5 }
for each 中同樣要用到entrySet()方法,具體如果對entrySet方法有疑問,請自行百度,本文不過多描述。
結語:由於Iterator類封裝在java.util路徑下,所以要使用Iterator需先import java.util.Iterator;或者import java.util.*;