List<String> k = new ArrayList<>();
k.add("lab1 ends");
Irerator it = k.iterator();
System.out.println(it.hasNext());
it.next();
System.out.println(it.hasNext());
k.remove(0);
System.out.println(it.hasNext());
接下来我们的输出应该为什么()
笔者在做这个题目的时候想到的答案是true、false、false,但是答案实际上是true、false、true,经过eclipse的实际验证,结果返回的确实是true、false、true
当时没有太理解,问了下徐老师解决了问题
我们可以看下java迭代器的源码,它的hasNext的判断逻辑是cursor != size
,而当它的下标超过我们最大的元素个数的时候是在next函数里抛出相应的异常,当我们通过list的remove方法对list进行操作时,相当于我们更改了list的size大小,使得我们当前的cursor和我们的list的size大小不等,因此返回了true,这道题目给我们的启示是我们的迭代器hasnext逻辑并不是我们通常认为的cursor < size 。
此外迭代其中如果使用list的remove方法会引起并发修改异常的产生,所以我们在使用迭代器的时候要使用迭代器的remove方法来减少可能的错误。