• java 数据结构(八):Iterator接口与foreach循环


    1.遍历Collection的两种方式:
    ① 使用迭代器Iterator ② foreach循环(或增强for循环)
    2.java.utils包下定义的迭代器接口:Iterator
    2.1说明:
    Iterator对象称为迭代器(设计模式的一种),主要用于遍历 Collection 集合中的元素。
    GOF给迭代器模式的定义为:提供一种方法访问一个容器(container)对象中各个元素,而又不需暴露该对象的内部细节。迭代器模式,就是为容器而生。
    2.2作用:遍历集合Collectiton元素
    2.3如何获取实例:coll.iterator()返回一个迭代器实例
    2.4遍历的代码实现:

    Iterator iterator = coll.iterator();
    //hasNext():判断是否还下一个元素
    while(iterator.hasNext()){
        //next():①指针下移 ②将下移以后集合位置上的元素返回
        System.out.println(iterator.next());
    }

    2.5图示说明:

     2.6 remove()的使用:

    //测试Iterator中的remove()
    //如果还未调用next()或在上一次调用 next 方法之后已经调用了 remove 方法,再调用remove都会报IllegalStateException。
    //内部定义了remove(),可以在遍历的时候,删除集合中的元素。此方法不同于集合直接调用remove()
        @Test
        public void test3(){
            Collection coll = new ArrayList();
            coll.add(123);
            coll.add(456);
            coll.add(new Person("Jerry",20));
            coll.add(new String("Tom"));
            coll.add(false);
    
            //删除集合中"Tom"
            Iterator iterator = coll.iterator();
            while (iterator.hasNext()){
    //            iterator.remove();
                Object obj = iterator.next();
                if("Tom".equals(obj)){
                    iterator.remove();
    //                iterator.remove();
                }
    
            }
            //遍历集合
            iterator = coll.iterator();
            while (iterator.hasNext()){
                System.out.println(iterator.next());
            }
        }


    3.jdk5.0新特性--增强for循环:(foreach循环)

    1.遍历集合举例:

    @Test
    public void test1(){
        Collection coll = new ArrayList();
        coll.add(123);
        coll.add(456);
        coll.add(new Person("Jerry",20));
        coll.add(new String("Tom"));
        coll.add(false);
    
        //for(集合元素的类型 局部变量 : 集合对象)
        
        for(Object obj : coll){
            System.out.println(obj);
        }
    }

    说明:
    内部仍然调用了迭代器。

    2.遍历数组举例:

    @Test
    public void test2(){
        int[] arr = new int[]{1,2,3,4,5,6};
        //for(数组元素的类型 局部变量 : 数组对象)
        for(int i : arr){
            System.out.println(i);
        }
    }
  • 相关阅读:
    [转载]Install Opera 12.16 Web Browser in CentOS/RHEL and Fedora
    [转载]CentOS 6.5 安装五笔输入法
    [转载]Lenovo E431 装Centos7无线驱动安装
    ElasticSearch的按日期排序问题
    [转载]java自带线程池和队列详细讲解
    [转载]Redis后台启动
    [转载]Process工具类,提供设置timeout功能
    [转载]使用java.lang.Process类的简单例子
    [转载]SecureCRT 绝佳配色方案, 保护你的眼睛
    4.二叉搜索树转为有序双向链表(递归算法与非递归算法)
  • 原文地址:https://www.cnblogs.com/qiu-hua/p/13184261.html
Copyright © 2020-2023  润新知