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 중국어 웹사이트의 기타 관련 기사를 참조하세요!