集合深度学习06—iterator 迭代器源码解析

一、面试题 iterator

iterator() 、 Iterator() 、Iterable 区别

ArrayList类 —继承—>AbstractList抽象类—实现—>List接口—继承—>Collections接口—继承—>Iterable接口
Iterable接口中有iterable抽象方法,返回类型是 Iterator接口,这个接口里有两个常用的方法 next和hasNext
ArrayList类中有个叫 Itr 内部类,实现了 Iterable接口,重写iterator方法,返回 Ire 对象

  • 为什么ArrayList继承了AbstractList抽象类还要实现List接口,因为作者承认自己写错了。
    在这里插入图片描述

二、迭代器具体实现

hasNext 和 next
在这里插入图片描述

增强for也是用的迭代器

三、ListIterator迭代器

在cc后面添加kk

		Iterator<String> it = list.iterator();
        while(it.hasNext()){
            if("cc".equals(it.next())){
                list.add("kk");
            }
        }

看着没问题,但会报并发修改异常
在这里插入图片描述
出错原因:就是迭代器和list修改同时对集合进行操作
解决方法:两个操作让一个迭代器进行。

        //在"cc"之后添加一个字符串"kk"
        ListIterator<String> it = list.listIterator();
        while(it.hasNext()){
            if("cc".equals(it.next())){
                list.add("kk");
            }
        }

ListIterator的两个判断方法:

  1. hasNext() 查看有没有下一个元素,正向遍历
  2. hasPrevious() 查看有没有上一个元素,逆向遍历
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值