Java LinkedList spliterator() 方法
定义和用法
spliterator() 方法为列表返回 Spliterator。
Spliterator 是一种特殊的迭代器。要了解如何使用迭代器,请参阅我们的 Java 迭代器教程。
Spliterator 与普通迭代器有很大不同。Spliterator 的目的是将集合拆分成更小的部分,以便每个部分可以由单独的线程处理。Spliterator 接口有两个重要的方法:
trySplit()- 返回新的Spliterator,它可以遍历(通常且大约)原始Spliterator可访问元素的一半,而原始Spliterator可以遍历剩余的一半。tryAdvance(Consumer action)- 移动到Spliterator可用的下一个项目,并尝试对其执行操作。如果没有下一个项目,则返回false。操作可以通过 lambda 表达式定义。
相关页面
教程:Java 数组
教程:Java 迭代器
实例
使用 Spliterator 遍历列表中的项目:
import java.util.LinkedList;
import java.util.Spliterator;
public class Main {
public static void main(String[] args) {
// 创建一个集合
LinkedList<String> cars = new LinkedList<String>();
cars.add("Volvo");
cars.add("BMW");
cars.add("Ford");
cars.add("Mazda");
// 获取 Spliterator 并尝试拆分它
Spliterator<String> it1 = cars.spliterator();
Spliterator<String> it2 = it1.trySplit();
// 遍历第一个 Spliterator
System.out.println("First spliterator");
it1.forEachRemaining(System.out::println);
// 遍历第二个 Spliterator
System.out.println("\nSecond spliterator");
if (it2 != null) {
it2.forEachRemaining(System.out::println);
}
}
}
注意:语法 while( it1.tryAdvance( (n) -> { System.out.println(n); } ) ); 等同于:
boolean x = it1.tryAdvance( (n) -> { System.out.println(n); });
while(x) {
x = it1.tryAdvance( (n) -> { System.out.println(n); });
}
语法
public Spliterator spliterator()
技术细节
| 返回: | Spliterator 对象。 |
|---|---|
| Java 版本: | 1.8+ |