Enumeration接口本身不是一个数据结构。但是,对其他数据结构非常重要。 Enumeration接口定义了从一个数据结构得到连续数据的手段。例如,Enumeration定义了一个名为nextElement的方法,可以用来从含有多个元素的数据结构中得到的下一个元素。 Enumeration接口提供了一套标准的方法,由于Enumeration是一个接口,它的角色局限于为数据结构提供方法协议。下面是一个使用的例子: //e is an object that implements the Enumeration interface while (e.hasMoreElements()) { Object o= e.nextElement(); System.out.println(o); } 实现该接口的对象由一系列的元素组成,可以连续地调用nextElement()方法来得到 Enumeration枚举对象中的元素。Enumertion接口中仅定义了下面两个方法。 ·boolean hasMoreElemerts() 测试Enumeration枚举对象中是否还含有元素,如果返回true,则表示还含有至少一个的元素。 ·Object nextElement() 如果Bnumeration枚举对象还含有元素,该方法得到对象中的下一个元素。
1 Enumeration接口介绍
Enumeration接口是Iterator迭代器的“古老版本”,从JDK1.0开始,Enumeration接口就已经存在了(Iterator从JDK1.2才出现)。Enumeration 接口比Iterator小,只有两个名字很长的方法:
- boolean hasMoreElements( ):如果此迭代器还有剩下的元素则返回true。
- Object nextElement( ):返回该迭代器的下一个元素,如果还有的话(否则抛出异常)。
2 代码示例
Java代码
-
import java.util.*; public class EnumerationTest { public static void main(String[] args) { Vector v = new Vector(); v.add("电信用户"); v.add("联通用户"); Hashtable scores = new Hashtable(); scores.put("线性代数" , 78); scores.put("大学物理" , 88); Enumeration em = v.elements(); while (em.hasMoreElements()) { System.out.println(em.nextElement()); } Enumeration keyEm = scores.keys(); while (keyEm.hasMoreElements()) { Object key = keyEm.nextElement(); System.out.println(key + "--->" + scores.get(key)); } } }
3 运行结果
电信用户
联通用户
大学物理--->88
线性代数--->78
4 结果分析
上面的程序使用Enumeration迭代器来遍历Vector和Hashtable集合里的元素,其工作方式和Iterator迭代器的工作方式基本相似。但使用该迭代器时方法名更加冗长,而且Enumeration迭代器支能遍历Vector和Hashtable这种古老的集合,因此不要使用它。除非在很极端的情况下,不得不使用Enumeration,否则都应该选择Iterator迭代器。