>  기사  >  Java  >  Java에서 Splitter 작업을 위해 Spliterator 기능을 사용하는 방법

Java에서 Splitter 작업을 위해 Spliterator 기능을 사용하는 방법

WBOY
WBOY원래의
2023-06-26 17:58:401802검색

Java 8에는 데이터 스트림에서 분할 작업을 수행하는 데 사용할 수 있는 새로운 인터페이스 Spliterator("split-iterator" 분할기)가 추가되었습니다. 이 인터페이스는 일련의 요소를 작은 덩어리로 분할할 수 있으며, 더 나은 성능을 위해 별도로 처리하고 병렬 방식으로 처리할 수 있습니다.

이 기사에서는 Splitter 작업을 위해 Spliterator 인터페이스를 사용하는 방법을 알아봅니다.

  1. Spliterator란 무엇입니까

Spliterator는 데이터 스트리밍 처리를 지원하는 데 사용되는 Java 8의 새로운 인터페이스입니다. 이는 "split-iterator"의 약어로, 데이터 스트림을 여러 개의 작은 조각으로 나눌 수 있고 이러한 작은 조각을 독립적으로 처리할 수 있음을 의미합니다. 이 인터페이스는 컬렉션, 배열, I/O 버퍼 및 Java 스트림과 같은 데이터 컬렉션을 처리하는 데 사용할 수 있습니다.

Spliterator 인터페이스에는 몇 가지 일반적인 메서드가 있습니다.

① tryAdvance() 메서드:
이 메서드는 데이터 스트림의 각 요소를 처리하는 데 사용됩니다. 처리할 요소가 더 이상 없으면 false를 반환합니다. .

② trySplit() 메서드:
이 메서드는 데이터 스트림을 병렬로 처리할 수 있는 두 개의 하위 컬렉션으로 분할합니다. 데이터 스트림이 분할하기에 너무 작으면 null이 반환됩니다.

3 estimateSize() 메서드:
이 메서드는 데이터 스트림의 요소 수에 대한 추정치를 반환합니다.

4 특성() 메서드:
이 메서드는 데이터 스트림에 있는 요소의 특성을 반환합니다.

  1. Spliterator 사용 방법

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의 Spiderrator 메소드를 호출하고 Spliterator 인스턴스 s1을 얻었습니다. 그런 다음 이 Spliterator의 메서드를 사용하여 데이터 스트림에 대한 분할 작업을 구현할 수 있습니다.

먼저 데이터 스트림의 예상 요소 수를 반환하는 estimateSize() 메서드를 호출합니다. 데이터 스트림에 있는 요소의 특성을 반환하기 위해 특성() 메서드를 호출했습니다.

그런 다음 forEachRemaining() 메서드를 사용하여 전체 스트림의 모든 요소를 ​​반복합니다. 이 메서드의 매개 변수는 각 요소를 처리하는 Lambda 표현식입니다.

다음으로 trySplit() 메서드를 호출하여 데이터 스트림을 두 개의 하위 집합 s1과 s2로 분할했습니다. forEachRemaining() 메서드를 사용하여 분할된 s1과 s2의 요소를 각각 인쇄합니다.

  1. 요약

Java 8의 Spliterator 인터페이스를 사용하여 데이터 스트림에서 분할 작업을 수행할 수 있습니다. 데이터 스트림을 작은 청크로 분할하고 이러한 청크를 병렬로 처리하여 효율성을 향상시킬 수 있습니다. Spliterator 인터페이스의 메소드를 구현함으로써 컬렉션, 배열, I/O 버퍼 및 Java 스트림과 같은 데이터 컬렉션에 대해 작업을 수행할 수 있습니다. 이 인터페이스는 데이터 스트림을 처리하는 보다 편리하고 효율적인 방법을 제공합니다.

위 내용은 Java에서 Splitter 작업을 위해 Spliterator 기능을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.