從源碼能夠看出,Iterator除了能讀取集合的數據以外,也能數據進行刪除操做;而Enumeration只能讀取集合的數據,而不能對數據進行修改。java
Iterator支持fail-fast機制,而Enumeration不支持fail-fast機制。Enumeration 是JDK 1.0添加的接口。使用到它的函數包括Vector、Hashtable等類,這些類都是JDK 1.0中加入的。Iterator是JDK1.2添加的接口,Iterator是基於Enumeration實現的,同時Iterator支持fail-fast機制,因此Iterator遍歷集合時會比Enumeration遍歷集合慢一些。函數
使用一個Hashtable集合,而後分別經過 Iterator 和 Enumeration 去遍歷它,比較它們的效率。代碼以下:ui
Iterator是一個接口,它的源碼以下:spa
package java.util; import java.util.function.Consumer; public interface Iterator<E> { //返回迭代器剛越過的元素的引用,返回值是Object,須要強制轉換成本身須要的類型 boolean hasNext(); //判斷容器內是否還有可供訪問的元素,返回值是E E next(); //刪除迭代器剛越過的元素 default void remove() { throw new UnsupportedOperationException("remove"); } default void forEachRemaining(Consumer<? super E> action) { Objects.requireNonNull(action); while (hasNext()) action.accept(next()); } }
Enumeration也是一個接口,它的源碼以下:code
package java.util; public interface Enumeration<E> { boolean hasMoreElements(); E nextElement(); }
使用一個Hashtable集合,而後分別經過 Iterator 和 Enumeration 去遍歷它,比較它們的效率。代碼以下:blog
注意Hashtable的 接口
(1) table.keys,table.elements 都是 Enumeration迭代器使用的element
(2) table.keySet(),table.values,table.entry 都是Iterator的迭代器使用的:rem
Hashtable<String,Integer> table=new Hashtable<>(); for(int i=0;i<100;i++){ table.put(String.valueOf(i),i); } //1 Enumeration: int index=0; Enumeration<String> en =table.keys(); while(en.hasMoreElements()){ String key= en.nextElement(); System.out.println("index="+(index++)+"key="+key+" value="+table.get(key)); } index=0; //2 Enumeration<Integer> en2=table.elements(); while(en2.hasMoreElements()){ Integer value= en2.nextElement(); System.out.println("2=index="+(index++)+" value="+value); } //3 Iterator index=0; Iterator<String> it=table.keySet().iterator(); while(it.hasNext()){ String key= it.next(); System.out.println("3=index="+(index++)+"key="+key+" value="+table.get(key)); } // 4 Iterator index=0; Iterator<Integer> it4=table.values().iterator(); while(it4.hasNext()){ Integer value=it4.next(); System.out.println("4=index="+(index++)+" value="+value); } // 5 Iterator index=0; Iterator<Map.Entry<String,Integer>> it5=table.entrySet().iterator(); while(it5.hasNext()){ Map.Entry<String,Integer> entry=it5.next(); System.out.println("5=index="+(index++)+" key"+entry.getKey()+" value="+entry.getValue()); }