ListIterator是Iterator的子接口,用于List集合双向遍历,支持前后移动、修改、添加元素及获取索引;通过list.listIterator()或list.listIterator(index)获取实例;正向遍历时用hasNext()和next(),反向时用hasPrevious()和previous();可从指定位置开始遍历,如list.listIterator(list.size())实现从末尾反向遍历;适用于逆序处理、边遍历边修改和定位操作等场景。

在Java中,ListIterator 是 Iterator 的子接口,专门用于List集合的双向遍历。与普通的 Iterator 只能单向向前遍历不同,ListIterator 支持从前往后和从后往前两个方向遍历,同时还能修改元素、添加元素以及获取当前索引位置。
要使用 ListIterator,必须通过实现 List 接口的集合(如 ArrayList、LinkedList)调用 listIterator() 方法获取实例。
示例:使用 hasNext() 和 next() 方法实现正向遍历,这与普通 Iterator 类似。
代码示例:
List<String> list = new ArrayList<>();
list.add("A");
list.add("B");
list.add("C");
ListIterator<String> iterator = list.listIterator();
while (iterator.hasNext()) {
String element = iterator.next();
System.out.println("正向: " + element + ", 索引: " + iterator.previousIndex());
}
在正向遍历之后,可以继续使用 hasPrevious() 和 previous() 方法反向遍历,前提是遍历指针未到达列表开头。
立即学习“Java免费学习笔记(深入)”;
接上例继续反向遍历:
while (iterator.hasPrevious()) {
String element = iterator.previous();
System.out.println("反向: " + element + ", 索引: " + iterator.previousIndex());
}
注意:调用 previous() 返回的是前一个元素,此时 previousIndex() 返回的是该元素的索引减一。
ListIterator<String> it = list.listIterator(list.size()); // 指针指向末尾
while (it.hasPrevious()) {
System.out.println("反向元素: " + it.previous());
}
以上就是在Java中如何使用ListIterator进行双向遍历的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号