zoukankan      html  css  js  c++  java
  • 集合之Iterator迭代器

    terator迭代器概述:

    java中提供了很多个集合,它们在存储元素时,采用的存储方式不同。我们要取出这些集合中的元素,可通过一种通用的获取方式来完成。

    Collection集合元素的通用获取方式:在取元素之前先要判断集合中有没有元素,如果有,就把这个元素取出来,继续在判断,如果还有就再取出出来。一直把集合中的所有元素全部取出。这种取出方式专业术语称为迭代。

    集合中把这种取元素的方式描述在Iterator接口中。Iterator接口的常用方法如下:

    hasNext()方法:用来判断集合中是否有下一个元素可以迭代。如果返回true,说明可以迭代。

    next()方法:用来返回迭代的下一个元素,并把指针向后移动一位。

    迭代集合元素图解:

     Iterator迭代方式的代码体现:

    在Collection接口描述了一个抽象方法iterator方法,所有Collection子类都实现了这个方法,并且有自己的迭代形式。

    //1,创建集合对象。
    Collection<String> coll = new ArrayList<String>();
    coll.add("abc1");
    coll.add("abc2");
    coll.add("abc3");
    coll.add("abc4");
      
    //2.获取容器的迭代器对象。通过iterator方法。
    Iterator it = coll.iterator();
      
    //3,使用具体的迭代器对象获取集合中的元素。参阅迭代器的方法
    while(it.hasNext()){
        System.out.println(it.next());
    }
      
    /*
    迭代器for循环的形式的使用
    for (Iterator it = coll.iterator(); it.hasNext(); ) {
        System.out.println(it.next());
    }
    */

    1.1     集合元素的向下转型

    集合中可以存储任何对象,那么存放进去的数据都是还是原来类型吗?不是了,提升成了Object。

    在使用集合时,需要注意以下几点:

    集合中存储其实都是对象的地址。

    集合中可以存储基本数值吗?jdk1.5版本以后可以存储了。因为出现了基本类型包装类,它提供了自动装箱操作(基本类型à对象),这样,集合中的元素就是基本数值的包装类对象。

    存储时提升了Object。取出时要使用元素的特有内容,必须向下转型。

    Collection coll = new ArrayList();
    coll.add("abc");
    coll.add("aabbcc");
    coll.add(1);
    Iterator it = coll.iterator();
    while (it.hasNext()) {
        //由于元素被存放进集合后全部被提升为Object类型
    //当需要使用子类对象特有方法时,需要向下转型
        String str = (String) it.next();
        System.out.println(str.length());
    }

    注意:如果集合中存放的是多个对象,这时进行向下转型会发生类型转换异常。

    提示:Iterator接口也可以使用<>来控制迭代元素的类型的。代码演示如下:

    Collection<String> coll = new ArrayList<String>();
    coll.add("abc");
    coll.add("aabbcc");
    coll.add("cat");
    Iterator<String> it = coll.iterator();
    while (it.hasNext()) {
        String str = it.next();
    //当使用Iterator<String>控制元素类型后,就不需要强转了。获取到的元素直接就是String类型
        System.out.println(str.length());
    }
  • 相关阅读:
    leetcode:Power of Two
    求二进制中1的个数
    leetcode:Contains Duplicate和Contains Duplicate II
    leetcode:Summary Ranges
    leetcode Database1(三)
    c++作业:使用函数调用的方法,实现求两个整数中大的数的程序。
    Java制作桌面弹球下载版 使用如鹏游戏引擎制作 包含2个精灵球同时弹动
    Java动画 重力弹球 如鹏游戏引擎 精灵 设计一个小球加速落地又减速弹起并反复直到停止的Java程序
    为什么方差的分母有时是n,有时是n-1 源于总体方差和样本方差的不同
    计算机应用第三次作业:自动开机自动关机 常用DOS命令 关于文件文件夹
  • 原文地址:https://www.cnblogs.com/a709898670/p/9413200.html
Copyright © 2011-2022 走看看