Java教程

一道比较费解的题目

本文主要是介绍一道比较费解的题目,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

一道比较费解的题目

题目描述

题目的代码如下:

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方法来减少可能的错误。

这篇关于一道比较费解的题目的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!