在Java集合中,咱们一般都经过 “Iterator(迭代器)” 或 “Enumeration(枚举类)” 去遍历集合。java
Enumeration是一个接口,它的源码以下:dom
package java.util; public interface Enumeration<E> { boolean hasMoreElements(); E nextElement(); }
Iterator也是一个接口,它的源码以下:函数
package java.util; public interface Iterator<E> { boolean hasNext(); E next(); void remove(); }
Enumeration只有2个函数接口。经过Enumeration,咱们只能读取集合的数据,而不能对数据进行修改。测试
Iterator只有3个函数接口。Iterator除了能读取集合的数据以外,也能数据进行删除操做。线程
Iterator支持fail-fast机制,而Enumeration不支持。Iterator 是JDK 1.2才添加的接口,它也是为了HashMap、ArrayList等集合提供遍历接口。Iterator是支持fail-fast机制的:当多个线程对同一个集合的内容进行操做时,就可能会产生fail-fast事件。code
import java.util.Enumeration; import java.util.Hashtable; import java.util.Iterator; import java.util.Map.Entry; import java.util.Random; /* * 测试分别经过 Iterator 和 Enumeration 去遍历Hashtable * @author skywang */ public class IteratorEnumeration { public static void main(String[] args) { int val; Random r = new Random(); Hashtable table = new Hashtable(); for (int i=0; i<100000; i++) { // 随机获取一个[0,100)之间的数字 val = r.nextInt(100); table.put(String.valueOf(i), val); } // 经过Iterator遍历Hashtable iterateHashtable(table) ; // 经过Enumeration遍历Hashtable enumHashtable(table); } /* * 经过Iterator遍历Hashtable */ private static void iterateHashtable(Hashtable table) { long startTime = System.currentTimeMillis(); Iterator iter = table.entrySet().iterator(); while(iter.hasNext()) { //System.out.println("iter:"+iter.next()); iter.next(); } long endTime = System.currentTimeMillis(); countTime(startTime, endTime); } /* * 经过Enumeration遍历Hashtable */ private static void enumHashtable(Hashtable table) { long startTime = System.currentTimeMillis(); Enumeration enu = table.elements(); while(enu.hasMoreElements()) { //System.out.println("enu:"+enu.nextElement()); enu.nextElement(); } long endTime = System.currentTimeMillis(); countTime(startTime, endTime); } private static void countTime(long start, long end) { System.out.println("time: "+(end-start)+"ms"); } }
输出结果接口
time: 9ms time: 5ms
从中,咱们能够看出。Enumeration 比 Iterator 的遍历速度更快。为何呢? 这是由于,Hashtable中Iterator是经过Enumeration去实现的,并且Iterator添加了对fail-fast机制的支持;因此,执行的操做天然要多一些。事件