>Java >java지도 시간 >Java 8의 `platMap()`이 `findFirst()`의 단락을 방지하는 이유는 무엇입니까?

Java 8의 `platMap()`이 `findFirst()`의 단락을 방지하는 이유는 무엇입니까?

DDD
DDD원래의
2024-12-24 16:25:13486검색

Why Does Java 8's `flatMap()` Prevent `findFirst()` from Short-Circuiting?

Java 8 스트림의 지연 실행: FlatMap() 및 FindFirst() 상호 작용 이해

Java 스트림 작업에서 flatMap() 연산자는 스트림의 각 요소를 새 스트림으로 변환한 다음 단일 스트림으로 평면화하는 데 사용됩니다. 그러나 findFirst() 터미널 작업과 함께 사용하면 지연 실행에 대한 의문을 제기하는 흥미로운 동작을 나타냅니다.

제공된 코드 조각에서 두 개의 스트림을 생성합니다. 하나는 filter()만 사용하고 하나는 다른 하나는 flatMap()과 filter()를 모두 사용합니다. 첫 번째 스트림은 실행을 즉시 종료하고 첫 번째 요소를 반환하지만 두 번째 스트림은 일치하는 요소를 찾았음에도 불구하고 전체 스트림을 계속 처리합니다.

왜 불일치합니까?

이러한 불일치를 이해하는 열쇠는 이러한 작업이 구현되는 방식에 있습니다. findFirst()는 단락 작업입니다. 즉, 일치하는 요소가 발견되면 실행을 중지할 수 있습니다. 그러나 flatMap() 이후에 사용하면 일치 항목이 이미 발견되었는지 여부에 관계없이 flatMap()에서 생성된 중간 스트림의 각 요소에 대해 filter() 작업이 실행됩니다.

이 동작은 다음으로 인해 발생합니다. JDK-8 스트림 구현의 제한 사항. flatMap()을 사용하면 결과 스트림이 완전히 게으르지 않습니다. 대신 소스 스트림에서 요소를 적극적으로 "가져오고" flatMap() 변환을 각 요소에 적용합니다. 즉, findFirst()가 일치 항목을 찾아 취소를 트리거한 후에도 이미 중간 스트림으로 가져온 요소는 filter() 연산자에 의해 계속 처리됩니다.

Java 10의 해결 방법 및 백포트

이 문제를 인식한 Java 개발자는 Java 10에서 이 문제를 수정하고 Java 8로 백포트했습니다. 버전에서는 flatMap()이 완전히 게으르게 만들어져 일치 항목이 발견되면 filter()와 같은 단락 작업이 스트림 실행을 올바르게 종료할 수 있습니다.

의미 및 고려 사항

이 문제는 이후 버전의 Java에서 해결되었지만 특히 flatMap()을 다음과 함께 사용할 때 스트림 작업의 지연 실행 특성을 이해하는 것이 중요하다는 점을 강조합니다. 단락 연산자.

애플리케이션에 지연 실행이 중요한 경우 이 문제가 해결된 Java 10 이상 버전을 사용하는 것이 좋습니다. 또는 flatMap() 변환에서 단락을 수동으로 구현하여 적절한 종료를 보장할 수 있습니다.

위 내용은 Java 8의 `platMap()`이 `findFirst()`의 단락을 방지하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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