list的迭代器的一道小题

    技术2022-07-17  75

    看到一道题关于list迭代器的题:

    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有点疑惑 去查了查大佬们的讲list迭代器实现的博客 发现它实现中有一个属性cursor指现在迭代器遍历到的位置的下一个 而迭代器hasNext()实现为 //private class public boolean hasNext() {   return cursor != size(); } 就是拿cursor和集合的size比较,不相同就说明未访问到最后一个元素,返回true。 在上述例子中运行it.next()之后,cursor应该指向遍历到位置的下一个也就是cursor=1。当运行k.remove(0)之后,size() 的结果应该变成了0,此时cursor!=size(),所以返回值为true

    Processed: 0.011, SQL: 9