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

在Java中,ListIterator 是 Iterator 的子接口,专门用于List集合的双向遍历。与普通的 Iterator 只能单向向前遍历不同,ListIterator 支持从前往后和从后往前两个方向遍历,同时还能修改元素、添加元素以及获取当前索引位置。
1. 获取 ListIterator 实例
要使用 ListIterator,必须通过实现 List 接口的集合(如 ArrayList、LinkedList)调用 listIterator() 方法获取实例。
示例:- 从头开始遍历:调用 list.listIterator()
- 从指定位置开始:调用 list.listIterator(index),index 为起始索引
2. 向前遍历(从前往后)
使用 hasNext() 和 next() 方法实现正向遍历,这与普通 Iterator 类似。
代码示例:Listlist = new ArrayList<>(); list.add("A"); list.add("B"); list.add("C"); ListIterator iterator = list.listIterator(); while (iterator.hasNext()) { String element = iterator.next(); System.out.println("正向: " + element + ", 索引: " + iterator.previousIndex()); }
3. 向后遍历(从后往前)
在正向遍历之后,可以继续使用 hasPrevious() 和 previous() 方法反向遍历,前提是遍历指针未到达列表开头。
Shopxp购物系统历经多年的考验,并在推出shopxp免费购物系统下载之后,收到用户反馈的各种安全、漏洞、BUG、使用问题进行多次修补,已经从成熟迈向经典,再好的系统也会有问题,在完善的系统也从在安全漏洞,该系统完全开源可编辑,当您下载这套商城系统之后,可以结合自身的技术情况,进行开发完善,当然您如果有更好的建议可从官方网站提交给我们。Shopxp网上购物系统完整可用,无任何收费项目。该系统经过
立即学习“Java免费学习笔记(深入)”;
接上例继续反向遍历:
while (iterator.hasPrevious()) {
String element = iterator.previous();
System.out.println("反向: " + element + ", 索引: " + iterator.previousIndex());
}
注意:调用 previous() 返回的是前一个元素,此时 previousIndex() 返回的是该元素的索引减一。
4. 双向遍历的典型应用场景
- 逆序处理数据:不需要额外反转列表即可从尾部开始处理
- 边遍历边修改:ListIterator 提供 add()、set()、remove() 方法,可在遍历过程中安全修改集合
- 定位操作:通过 nextIndex() 和 previousIndex() 获取当前位置,便于插入或删除
ListIterator基本上就这些。ListIterator 让 List 的遍历更灵活,尤其适合需要来回移动或在遍历中修改集合的场景。it = list.listIterator(list.size()); // 指针指向末尾 while (it.hasPrevious()) { System.out.println("反向元素: " + it.previous()); }









