其他分享
首页 > 其他分享> > 一道比较费解的题目

一道比较费解的题目

作者:互联网

一道比较费解的题目

题目描述

题目的代码如下:

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
image

当时没有太理解,问了下徐老师解决了问题
image
我们可以看下java迭代器的源码,它的hasNext的判断逻辑是cursor != size,而当它的下标超过我们最大的元素个数的时候是在next函数里抛出相应的异常,当我们通过list的remove方法对list进行操作时,相当于我们更改了list的size大小,使得我们当前的cursor和我们的list的size大小不等,因此返回了true,这道题目给我们的启示是我们的迭代器hasnext逻辑并不是我们通常认为的cursor < size 。

结论

此外迭代其中如果使用list的remove方法会引起并发修改异常的产生,所以我们在使用迭代器的时候要使用迭代器的remove方法来减少可能的错误。

标签:题目,迭代,费解,list,remove,一道,hasNext,true
来源: https://www.cnblogs.com/floralsea/p/16366159.html