Java集合中的迭代器遍历(超详细)

Collection提供了遍历集合的方式:迭代器模式  Iterator iterator() 该方法会返回一个用于遍历当前集合的迭代器
java.util.Iterator迭代器接口
所有的集合都提供了一个用于遍历自身元素的迭代器实现类,我们无需记住这些类的名字,只需要当它们为Iterator去操作即可。
迭代器遍历集合遵循的步骤为:问->取->删
其中删除元素不是遍历过程中的必要操作。
迭代器中两个重要的方法:
1.boolean hasNext():判断当前集合是否还有下一个元素可以遍历。
注:迭代器默认开始位置为集合第一个元素之前,所以第一次调用是判断集合是否有第一个
元素可以遍历。
2.E next():使迭代器向后移动到下一个元素的位置并获取该元素。
    public static void main(String[] args) {
        //新建一个集合并添加元素
        Collection c = new ArrayList();
        c.add("one");
        c.add("#");
        c.add("two");
        c.add("#");
        c.add("three");
        c.add("#");
        c.add("four");
        c.add("#");
        c.add("five");
        System.out.println(c);//[one, #, two, #, three, #, four, #, five]
     
        Iterator it = c.iterator();
        while(it.hasNext()){
            String str = (String)it.next();
            System.out.println(str);
            if("#".equals(str)){
                //迭代器要求在遍历的过程中不能通过集合的方法增删元素否则会抛出异常!
//                c.remove(str); //报异常
                //迭代器提供的remove可以删除迭代器当前位置表示的集合元素
               it.remove();
            }
        }
        System.out.println(c);//[one, two, three, four, five]
    }

Java集合中的迭代器遍历(超详细)_第1张图片

 

你可能感兴趣的:(java,开发语言)