Java迭代器-Iterator

单一职责原则

所有的集合的基本接口是Collection接口。它包含两个方法 (值得一提的是,Collection接口扩展了Iterable接口,因此实现Collection接口,也必须同时实现Iterable接口,从关系上来看,Collection接口是依赖于Iterable的)

Collection接口的方法
Collection
Iterable接口的方法
Iterable

这里需要注意的是,它提供了一个Iterator方法,返回了一个实现了Iterator接口的对象。那么这个Iterator接口又提供了什么方法呢?分别是hashNext()、next()、remove()、forEachRemaining(Consumer<? super E> action)

Iterator接口
Iterator

这个Iterator,就是所谓的迭代器了。

通过反复调用next方法,可以遍历集合中的每个元素,但是如果发生了数据越界,那么next方法会抛出NoSuchElementException.所以在next方法调用之前,我们需要先调用hasNext方法.

如何使用迭代器遍历集合中的元素
  • 使用传统的hasNext()&next()
        Collection<String> c = new HashSet<>();
        c.add("a");
        c.add("b");
        Iterator<String> iterator = c.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }

那么有没有更加好的遍历集合的办法呢?有,使用foreach.
forEachRemaining具体的访问顺序取决于你使用的集合类型,ArrayList是有序的,HashSet则不保证顺序.

        Collection<String> c = new HashSet<>();
        c.add("a");
        c.add("b");
        //foreach
        for (String element : c) {
            System.out.println(element);
        }
        //lambda
        c.forEach(element -> System.out.println(element));
此时插播一个问题:List如何在遍历中删除元素
  • 使用迭代器遍历,并且使用remove()方法
  • 使用for循环,每次remove的时候,记得让索引-1
  • 使用Java8提供的removeIf()(推荐)
错误示范:
foreach
正确示范:
        Collection<String> c = new HashSet<>();
        c.add("a");
        c.add("b");
        c.removeIf(e-> e.equals("a"));
        c.forEach(element -> System.out.println(element));
关于remove方法的一些说明

remove方法将会删除上次调用next方法时返回的元素。当你使用remove方法的时候,需要先获取到有意义的元素(即调用next方法)。在Java核心技术卷这本书中,强调了next方法与remove方法必须具备依赖性。

错误示范
        Collection<String> c = new HashSet<>();
        c.add("a");
        c.add("b");
        Iterator<String> iterator = c.iterator();
        iterator.remove();
正确示范
        Collection<String> c = new HashSet<>();
        c.add("a");
        c.add("b");
        Iterator<String> iterator = c.iterator();
        iterator.next();
        iterator.remove();
迭代器在集合中的作用

用于编写泛型接口,无需为同一个逻辑编写多个方法。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。