Enumeration与Iterator介绍

Enumeration

Enumeration简介

       Enumeration(列举),本身是一个接口,不是一个类。Enumeration接口本身不是一个数据结构。但是,对其他数据结构非常重要。 Enumeration接口定义了从一个数据结构得到连续数据的手段。实现 Enumeration 接口的对象,它生成一系列元素,一次生成一个。连续调用 nextElement 方法将返回一系列的连续元素。

       例如,要输出 Vector<E> v的所有元素,可使用以下方法:

 for (Enumeration<E> e = v.elements(); e.hasMoreElements();){
     System.out.println(e.nextElement());
 }

Enumeration 方法介绍

       Enumeration接口提供了一套标准的方法,主要通过向量的元素、哈希表的键以及哈希表中的值进行枚举。由于Enumeration是一个接口,它的角色局限于为数据结构提供方法协议,实现该接口的对象由一系列的元素组成,可以连续地调用nextElement()方法来得到 Enumeration枚举对象中的元素。Enumertion接口中仅定义了下面两个方法。

  1. boolean hasMoreElements()

测试此枚举是否包含更多的元素。

返回值:当且仅当此枚举对象至少还包含一个可提供的元素时,才返回 true;否则返回 false。

  1. E nextElement()

    如果此枚举对象至少还有一个可提供的元素,则返回此枚举的下一个元素。

    返回值:此枚举的下一个元素。

    抛出:NoSuchElementException - 如果没有更多的元素存在。

Enumeration代码举例

  1. 使用Enumeration遍历Vector集合
  import java.util.Enumeration;
  import java.util.Vector;  
  
  public class EnumerationTest {
        public static void main(String[] args) {
        
            Vector<String> vector = new Vector<String>();
            vector.addElement("Monday");
            vector.addElement("Tuesday");
            vector.addElement("Wednesday");
            vector.addElement("Thursday");
            
            Enumeration<String> elements = vector.elements();
            while (elements.hasMoreElements()) {
                System.out.println(elements.nextElement());
            }
        }
}

输出的结果为:

Monday
Tuesday
Wednesday
Thursday
  1. 使用Enumeration遍历HashTable(使用枚举获取key的值)
   import java.util.Enumeration;
   import java.util.Hashtable;  
     
   public class EnumerationTest {
       public static void main(String[] args) {

            Hashtable<String, String> table = new Hashtable<String, String>();
            table.put("星期一", "Monday");
            table.put("星期二", "Tuesday");
            table.put("星期三", "Wednesday");
            table.put("星期四", "Thursday");
            
            Enumeration<String> keys = table.keys();
            while (keys.hasMoreElements()) {
                String element= keys.nextElement();
                System.out.println(element);
            }
        }
    }

输出的结果为:

星期三
星期二
星期四
星期一
  1. 使用Enumeration遍历HashTable(使用枚举获取value值)
   import java.util.Enumeration;
   import java.util.Hashtable;  
     
   public class EnumerationTest {
       public static void main(String[] args) {

            Hashtable<String, String> table = new Hashtable<String, String>();
            table.put("星期一", "Monday");
            table.put("星期二", "Tuesday");
            table.put("星期三", "Wednesday");
            table.put("星期四", "Thursday");
            
            Enumeration<String> values= table.elements();
            while (values.hasMoreElements()) {
                String element= values.nextElement();
                System.out.println(element);
            }
        }
    }

输出的结果为:

Wednesday
Tuesday
Thursday
Monday

Iterator

Iterator简介

       Iterator(迭代器)取代了 Java Collections Framework(Java集合框架) 中的 Enumeration,迭代器与枚举有两点不同:

  • 迭代器允许调用者利用定义良好的语义在迭代期间从迭代器所指向的collection 移除元素。

  • 方法名称得到了改进。

Iterator方法介绍:

  1. boolean hasNext()

如果仍有元素可以迭代,则返回 true。(换句话说,如果 next 返回了元素而不是抛出异常,则返回 true)。

返回值:如果迭代器具有多个元素,则返回 true。
  1. E next()

    返回迭代的下一个元素。

    返回值:迭代的下一个元素。

    抛出:NoSuchElementException - 没有元素可以迭代。

  1. void remove()

从迭代器指向的 collection 中移除迭代器返回的最后一个元素(可选操作)。每次调用 next 只能调用一次此方法。如果进行迭代时用调用此方法之外的其他方式修改了该迭代器所指向的 collection,则迭代器的行为是不确定的。

抛出:

  • UnsupportedOperationException - 如果迭代器不支持 remove 操作。
  • IllegalStateException - 如果尚未调用 next 方法,或者在上一次调用 next 方法之后已经调用了 remove 方法。

Iterator代码举例

       这里使用Iterator遍历list单列集合,对于map多列集合,在调用keySet()方法或者是entrySet()方法之后同样也是相当于单列集合了。

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class IteratorTest {

    public static void main(String[] args) {
        
        List<String> list = new ArrayList<String>();
        list.add("Monday");
        list.add("Tuesday");
        list.add("Wednesday");
        
        Iterator<String> iterator = list.iterator();
        while (iterator.hasNext()) {
            System.out.println(iterator.next());
        }
    }
}

输出结果为:

Monday
Tuesday
Wednesday

调用Iterator的remove()方法:

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class IteratorTest {

    public static void main(String[] args) {
        
        List<String> list = new ArrayList<String>();
        list.add("Monday");
        list.add("Tuesday");
        list.add("Wednesday");
        
        Iterator<String> iterator = list.iterator();
        while (iterator.hasNext()) {
            if ("Wednesday".equals(iterator.next())) {
                iterator.remove();
            }
            System.out.println(list);
        }
    }
}

输出的结果:

[Monday, Tuesday, Wednesday]
[Monday, Tuesday, Wednesday]
[Monday, Tuesday]

注意:每次循环中最好只使用一次next()方法,因为使用一次,指针就会往下走一个,如果在一个循环中使用了两次next()方法,可能会出现NoSuchElementException 的异常,例如:

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class IteratorTest {

    public static void main(String[] args) {
        
        List<String> list = new ArrayList<String>();
        list.add("Monday");
        list.add("Tuesday");
        list.add("Wednesday");
        
        Iterator<String> iterator = list.iterator();
        while (iterator.hasNext()) {
            if (iterator.next() != null && !"".equals(iterator.next())) {
                // 逻辑处理
            }
        }
    }
}

上面代码,循环一次,指针向后移动两位,这样在第二次循环时,第二个iterator.next()会抛异常。

同样需要注意remove()方法,每次调用只能够在调用了next()方法的前提下才可以移除响应元素。如果调用了多个next()方法后再调用remove()方法,则移除的时最后一次调用next()方法返回的元素。例如:

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class IteratorTest {

    public static void main(String[] args) {
        
        List<String> list = new ArrayList<String>();
        list.add("Monday");
        list.add("Tuesday");
        list.add("Wednesday");
        list.add("Thursday");
        
        Iterator<String> iterator = list.iterator();
        while (iterator.hasNext()) {
            if (iterator.next() != null && !"".equals(iterator.next())) {
                iterator.remove();
            }
            System.out.println(list);
        }
    }
}

输出的结果为:

[Monday, Wednesday, Thursday]
[Monday, Wednesday]

总结

Enumeration接口是JDK1.0时推出的,在JDK1.5之后为Enumeration接口进行了扩充,增加了泛型的操作应用。Iterator迭代器取代了 Enumeration的功能,同时增添了删除元素的方法,并且对方法的名称进行了改进。为什么还要使用Enumeration?这是因为java的发展经历了很长时间,一些比较古老的系统或者类库中的方法还在使用Enumeration接口,因此为了兼容,还是需要使用Enumeration。已知的对于vactor和hashtable的遍历还可能会使用Enumeration。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,524评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,869评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,813评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,210评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,085评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,117评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,533评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,219评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,487评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,582评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,362评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,218评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,589评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,899评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,176评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,503评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,707评论 2 335

推荐阅读更多精彩内容

  • 1 场景问题# 1.1 工资表数据的整合## 考虑这样一个实际应用:整合工资表数据。 这个项目的背景是这样的,项目...
    七寸知架构阅读 2,494评论 0 53
  • 1.Java集合框架是什么?说出一些集合框架的优点? 每种编程语言中都有集合,最初的Java版本包含几种集合类:V...
    joshul阅读 372评论 0 2
  • Collection接口 Collection接口是所有集合的祖先类。他有两个构造方法,一个无参构造,一个是带Co...
    夜幕繁华阅读 575评论 0 0
  • 生活是杯苦的黑咖啡, 能把它喝淡的, 喝香的, 就是我的老师。
    舒己怀_Frank阅读 274评论 11 14
  • 持续 直接就到双十二了,昨天那上吐下泻先不谈。我终于知道我为什么总是只能比别人厉害一点点了。因为我没有办法坚持,我...
    沙师弟23阅读 189评论 0 0