Java ListIterator 接口
提示
- 双向迭代功能:
ListIterator
是一个双向迭代器,允许在两个方向上遍历列表。 - 主要方法:提供
hasNext()
,next()
,previous()
,nextIndex()
,previousIndex()
,remove()
,set()
等方法来操作列表。 - 使用示例:示例展示了如何使用
ListIterator
在ArrayList
中进行元素的访问和位置检索。
Java 集合框架中的 ListIterator
接口提供了访问列表元素的功能。
它是双向的。这意味着它允许我们在两个方向上迭代列表中的元素。
它扩展了 Iterator
接口。
List
接口提供了一个 listIterator()
方法,该方法返回 ListIterator
接口的实例。
ListIterator 的方法
ListIterator
接口提供了可以用于对列表元素执行各种操作的方法。
hasNext()
- 如果列表中存在元素,则返回 truenext()
- 返回列表的下一个元素nextIndex()
- 返回next()
方法将返回的元素的索引previous()
- 返回列表的上一个元素previousIndex()
- 返回previous()
方法将返回的元素的索引remove()
- 移除next()
或previous()
返回的元素set()
- 用指定元素替换next()
或previous()
返回的元素
示例 1:ListIterator 的实现
在下面的示例中,我们在数组列表中实现了 ListIterator
接口的 next()
、nextIndex()
和 hasNext()
方法。
import java.util.ArrayList;
import java.util.ListIterator;
class Main {
public static void main(String[] args) {
// 创建一个 ArrayList
ArrayList<Integer> numbers = new ArrayList<>();
numbers.add(1);
numbers.add(3);
numbers.add(2);
System.out.println("ArrayList: " + numbers);
// 创建 ListIterator 的实例
ListIterator<Integer> iterate = numbers.listIterator();
// 使用 next() 方法
int number1 = iterate.next();
System.out.println("下一个元素: " + number1);
// 使用 nextIndex()
int index1 = iterate.nextIndex();
System.out.println("下一个元素的位置: " + index1);
// 使用 hasNext() 方法
System.out.println("是否有下一个元素? " + iterate.hasNext());
}
}
输出
ArrayList: [1, 3, 2]
下一个元素: 1
下一个元素的位置: 1
是否有下一个元素? true
示例 2:ListIterator 的实现
在下面的示例中,我们在数组列表中实现了 ListIterator
接口的 previous()
和 previousIndex()
方法。
import java.util.ArrayList;
import java.util.ListIterator;
class Main {
public static void main(String[] args) {
// 创建一个 ArrayList
ArrayList<Integer> numbers = new ArrayList<>();
numbers.add(1);
numbers.add(3);
numbers.add(2);
System.out.println("ArrayList: " + numbers);
// 创建 ListIterator 的实例
ListIterator<Integer> iterate = numbers.listIterator();
iterate.next();
iterate.next();
// 使用 previous() 方法
int number1 = iterate.previous();
System.out.println("上一个元素: " + number1);
// 使用 previousIndex()
int index1 = iterate.previousIndex();
System.out.println("上一个元素的位置: " + index1);
}
}
输出
ArrayList: [1, 3, 2]
上一个元素: 3
上一个元素的位置: 0
在上述示例中,最初 Iterator
的实例在 1 之前。由于 1 之前没有元素,所以调用 previous()
方法将抛出异常。
然后我们两次使用了 next()
方法。现在 Iterator
实例将在 3 和 2 之间。
因此,previous()
方法返回 3。