Java 8에는 데이터 스트림에서 분할 작업을 수행하는 데 사용할 수 있는 새로운 인터페이스 Spliterator("split-iterator" 분할기)가 추가되었습니다. 이 인터페이스는 일련의 요소를 작은 덩어리로 분할할 수 있으며, 더 나은 성능을 위해 별도로 처리하고 병렬 방식으로 처리할 수 있습니다.
이 기사에서는 Splitter 작업을 위해 Spliterator 인터페이스를 사용하는 방법을 알아봅니다.
Spliterator는 데이터 스트리밍 처리를 지원하는 데 사용되는 Java 8의 새로운 인터페이스입니다. 이는 "split-iterator"의 약어로, 데이터 스트림을 여러 개의 작은 조각으로 나눌 수 있고 이러한 작은 조각을 독립적으로 처리할 수 있음을 의미합니다. 이 인터페이스는 컬렉션, 배열, I/O 버퍼 및 Java 스트림과 같은 데이터 컬렉션을 처리하는 데 사용할 수 있습니다.
Spliterator 인터페이스에는 몇 가지 일반적인 메서드가 있습니다.
① tryAdvance() 메서드:
이 메서드는 데이터 스트림의 각 요소를 처리하는 데 사용됩니다. 처리할 요소가 더 이상 없으면 false를 반환합니다. .
② trySplit() 메서드:
이 메서드는 데이터 스트림을 병렬로 처리할 수 있는 두 개의 하위 컬렉션으로 분할합니다. 데이터 스트림이 분할하기에 너무 작으면 null이 반환됩니다.
3 estimateSize() 메서드:
이 메서드는 데이터 스트림의 요소 수에 대한 추정치를 반환합니다.
4 특성() 메서드:
이 메서드는 데이터 스트림에 있는 요소의 특성을 반환합니다.
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의 요소를 각각 인쇄합니다.
Java 8의 Spliterator 인터페이스를 사용하여 데이터 스트림에서 분할 작업을 수행할 수 있습니다. 데이터 스트림을 작은 청크로 분할하고 이러한 청크를 병렬로 처리하여 효율성을 향상시킬 수 있습니다. Spliterator 인터페이스의 메소드를 구현함으로써 컬렉션, 배열, I/O 버퍼 및 Java 스트림과 같은 데이터 컬렉션에 대해 작업을 수행할 수 있습니다. 이 인터페이스는 데이터 스트림을 처리하는 보다 편리하고 효율적인 방법을 제공합니다.
위 내용은 Java에서 Splitter 작업을 위해 Spliterator 기능을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!