Java 8 では、新しいインターフェイス Spliterator (「分割イテレーター」スプリッター) が追加されました。これを使用して、データ ストリームに対してスプリッター操作を実行できます。このインターフェイスは、一連の要素を小さなチャンクに分割し、個別に処理したり、パフォーマンスを向上させるために並列処理したりできます。
この記事では、スプリッタ操作に Spliterator インターフェイスを使用する方法を学びます。
Spliterator は Java 8 の新しいインターフェイスで、データ ストリーミング処理をサポートするために使用されます。これは「split-iterator」の略語で、データ ストリームを複数の小さな部分に分割し、これらの小さな部分を独立して処理できることを意味します。このインターフェイスは、コレクション、配列、I/O バッファ、Java ストリームなどのデータ コレクションを処理するために使用できます。
Spliterator インターフェイスにはいくつかの共通メソッドがあります:
① tryAdvance() メソッド:
このメソッドは、データ ストリーム内の各要素を処理するために使用されます。要素を処理する必要がある場合は false を返し、それ以外の場合は true を返します。
② trySplit() メソッド:
このメソッドは、データ ストリームを 2 つのサブコレクションに分割し、並列処理できます。データ ストリームが小さすぎて分割できない場合は、null が返されます。
③estimateSize() メソッド:
このメソッドは、データ ストリーム内の要素数の推定値を返します。
④characteristics() メソッド:
このメソッドは、データ ストリーム内の要素の特性を返します。
Spliterator インターフェイスのメソッドを呼び出すことで、データ ストリームに対してスプリッター操作を実行できます。 Spliterator を使用したサンプル コードを次に示します。
import java.util.ArrayList; import java.util.List; import java.util.Spliterator; public class SplitIteratorExample { public static void main(String[] args) { List<String> names = new ArrayList<>(); names.add("John"); names.add("Mike"); names.add("Tom"); names.add("Jerry"); names.add("Peter"); Spliterator<String> s1 = names.spliterator(); System.out.println("Estimate size: " + s1.estimateSize()); System.out.println("Characteristics: " + s1.characteristics()); s1.forEachRemaining(name -> System.out.println(name)); Spliterator<String> s2 = s1.trySplit(); System.out.println("Spliterator s1"); s1.forEachRemaining(name -> System.out.println(name)); System.out.println("Spliterator s2"); s2.forEachRemaining(name -> System.out.println(name)); } }
このサンプル コードでは、文字列のリストを作成し、それを "names" という名前の List オブジェクトに保存します。 List の Thickator メソッドを呼び出し、Spliterator インスタンス s1 を取得しました。次に、この Spliterator のメソッドを使用して、データ ストリームにスプリッター操作を実装できます。
最初に、estimateSize() メソッドを呼び出します。このメソッドは、データ ストリーム内の要素の推定数を返します。特性() メソッドを呼び出して、データ ストリーム内の要素の特性を返しました。
次に、forEachRemaining() メソッドを使用して、ストリーム全体のすべての要素をループします。このメソッドのパラメータは、各要素を処理するための Lambda 式です。
次に、trySplit() メソッドを呼び出して、データ ストリームを 2 つのサブセット s1 と s2 に分割しました。 forEachRemaining() メソッドを使用して、分割された s1 と s2 の要素をそれぞれ出力します。
Java 8 の Spliterator インターフェイスを使用して、データ ストリームに対してスプリッター操作を実行できます。データ ストリームを小さなチャンクに分割し、これらのチャンクを並列処理して効率を向上させることができます。 Spliterator インターフェイスのメソッドを実装することにより、コレクション、配列、I/O バッファ、Java ストリームなどのデータ コレクションを操作できます。このインターフェイスは、データ ストリームを処理するためのより便利で効率的な方法を提供します。
以上がJavaでスプリッタ操作を行うためにSpliterator関数を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。