Java 8: Lambda-Streams - 예외를 발생시키는 메서드별 필터링
Java 8의 람다 표현식은 데이터를 조작하고 처리하는 강력한 방법을 제공합니다. 그러나 예외를 발생시킬 수 있는 메서드를 다룰 때는 람다 식의 한계를 탐색하고 효과적인 솔루션을 모색하는 것이 중요합니다.
문제:
다음 코드를 고려하세요. 조각:
<code class="java">class Bank { public Set<String> getActiveAccountNumbers() throws IOException { Stream<Account> s = accounts.values().stream(); s = s.filter(a -> a.isActive()); Stream<String> ss = s.map(a -> a.getNumber()); return ss.collect(Collectors.toSet()); } } interface Account { boolean isActive() throws IOException; String getNumber() throws IOException; }</code>
isActive 및 getNumber 메서드에서 발생한 확인된 예외로 인해 이 코드가 컴파일되지 않습니다. 람다 표현식 내에서 예외가 제대로 처리되지 않기 때문에 단순히 주변 try-catch 블록에서 예외를 잡는 것만으로는 충분하지 않습니다.
해결책:
극복하려면 이 문제에서는 람다 표현식을 탈출하기 전에 예외를 포착해야 합니다. 한 가지 접근 방식은 다음 수정된 코드 조각에서 볼 수 있듯이 확인되지 않은 예외를 사용하는 것입니다.
<code class="java">s = s.filter(a -> { try { return a.isActive(); } catch (IOException e) { throw new UncheckedIOException(e); } });</code>
여기서 람다 내에서 IOException을 포착하고 확인되지 않은 예외를 발생시켜 람다 내에서 올바르게 처리되는지 확인합니다.
또는 확인된 예외를 확인되지 않은 예외로 변환하는 래퍼 메서드를 사용할 수 있습니다.
<code class="java">return s.filter(a -> uncheckCall(a::isActive)) .map(Account::getNumber) .collect(toSet()); public static <T> T uncheckCall(Callable<T> callable) { try { return callable.call(); } catch (RuntimeException e) { throw e; } catch (Exception e) { throw new RuntimeException(e); } }</code>
이를 통해 uncheckCall 호출에서 람다 식을 래핑할 수 있습니다. 내부적으로 확인된 예외를 처리하여 람다 식에 확인된 예외 선언이 없도록 합니다.
기타 고려 사항:
특정 예외가 여전히 예외를 벗어날 수 있다는 사실에 유의하는 것이 중요합니다. 제안된 솔루션을 사용해도 람다 식을 사용할 수 있습니다. 예를 들어 수집 작업 평가 중에 발생한 예외는 여전히 람다 외부로 전파됩니다.
위 내용은 스트림을 필터링할 때 Java 8 Lambda 표현식의 예외를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!