Java 8에서 스트림 역방향 기술 탐색
Java 8에서 스트림을 처리할 때 순서를 역전시켜야 하는 경우가 흔합니다. 모든 스트림을 반전하는 올바른 접근 방식을 확인하기 위해 우리는 모든 유형의 스트림을 반전하기 위한 추가 솔루션을 탐색하는 동시에 IntStream을 반전하는 구체적인 과제를 조사합니다.
IntStream 반전:*
IntStream은 지정된 범위 내에서 정수를 생성하기 위한 range() 메서드를 제공합니다. 범위를 바꾸려면 인수를 조정하면 됩니다.
<code class="java">IntStream.range(-range, 0)</code>
그러나 이 접근 방식은 실용적이지 않으며 컴파일러 오류로 인해 Integer::compare를 사용할 수 없습니다. 대신 다음 코드를 고려하세요.
<code class="java">static IntStream revRange(int from, int to) { return IntStream.range(from, to) .map(i -> to - i + from - 1); }</code>
이 방법은 박싱이나 정렬 없이 범위를 반전합니다.
일반 스트림 반전:
다음이 있습니다. 모든 유형의 스트림을 역방향으로 변환하는 여러 가지 방법이 있지만 둘 다 elements.
배열 기반 반전:
이 방법은 배열을 사용하여 이후에 역순으로 읽을 수 있도록 요소를 저장합니다.
<code class="java">@SuppressWarnings("unchecked") static <T> Stream<T> reverse(Stream<T> input) { Object[] temp = input.toArray(); return (Stream<T>) IntStream.range(0, temp.length) .mapToObj(i -> temp[temp.length - i - 1]); }</code>
컬렉터 기반 반전:
컬렉터를 사용하여 축적할 수 있습니다. 요소를 역방향 목록으로:
<code class="java">Stream<T> input = ... ; List<T> output = input.collect(ArrayList::new, (list, e) -> list.add(0, e), (list1, list2) -> list1.addAll(0, list2));</code>
이 방법은 효과적이지만 많은 ArrayList.add(0, ...) 삽입을 트리거하여 과도한 복사를 초래합니다.
효율적 컬렉터 기반 반전:
복사 단점을 완화하려면 ArrayDeque 사용을 고려하세요. 효율적인 전면 삽입 지원:
<code class="java">Deque<String> output = input.collect(Collector.of( ArrayDeque::new, (deq, t) -> deq.addFirst(t), (d1, d2) -> { d2.addAll(d1); return d2; }));</code>
이 업데이트된 코드는 불필요한 복사를 제거하면서 Collector 기반 반전의 효율성을 유지합니다.
위 내용은 Java 8에서 스트림을 효율적으로 역방향하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!