Java 8의 Lambda 표현식 및 예외 스트림: 안전하게 메서드 필터링
Lambda 표현식은 Java 코딩에 혁명을 일으켜 간결하고 표현력이 풍부한 함수형 프로그래밍 기술을 가능하게 했습니다. . 그러나 제공된 예제에서처럼 예외를 발생시킬 수 있는 메서드를 처리할 때 Java 8 스트림 작업에서 컴파일 문제가 발생할 수 있습니다.
문제
코드 조각 시도 IOException을 발생시키는 isActive() 메소드를 기반으로 Account 객체의 스트림을 필터링합니다. Java에서는 확인된 예외를 스트림 내에서 명시적으로 처리해야 하므로 필터링 작업이 컴파일되지 않습니다.
해결책
이 문제를 해결하려면 잠재적인 예외를 처리해야 합니다. 람다 표현식을 벗어나기 전에. 이는 람다 내부의 try-catch 블록 내에서 isActive() 메서드 호출을 래핑하여 달성할 수 있습니다.
<code class="java">s = s.filter(a -> { try { return a.isActive(); } catch (IOException e) { throw new UncheckedIOException(e); } });</code>
확인된 IOException을 UncheckedIOException으로 변환하면 예외가 발생하지 않고 스트림 내에서 안전하게 전파될 수 있습니다. 컴파일 오류.
대체 방법
또는 uncheckCall() 메서드를 사용하여 중간 변환에 의존하지 않고 확인된 예외를 처리할 수 있습니다.
<code class="java">return s.filter(a -> uncheckCall(a::isActive)) .map(Account::getNumber) .collect(toSet());</code>
이 접근 방식은 람다 표현식의 간결성을 유지하면서 확인된 예외를 처리하는 편리한 방법을 제공합니다.
주의
checked 변환의 잠재적인 영향을 고려하는 것이 중요합니다. 확인되지 않은 항목에 대한 예외. 이는 스트림 작업에서 예외 처리를 단순화하는 동시에 메서드 시그니처에서 잠재적인 예외에 대한 직접적인 표시도 제거합니다. 이러한 방식으로 예외를 처리하는 것이 원하는 동작과 일치하도록 신중하게 고려해야 합니다.
위 내용은 Java 8에서 예외를 발생시키는 객체 스트림을 어떻게 안전하게 필터링할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!