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>
이 코드를 컴파일하려면 catch해야 합니다. isActive 및 getNumber 메소드의 잠재적인 IOException. 그러나 아래에 설명된 것처럼 단순히 try-catch 블록 내에서 예외를 처리하면 여전히 컴파일 오류가 발생합니다.
<code class="java">class Bank { public Set<String> getActiveAccountNumbers() throws IOException { try { 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()); } catch (IOException ex) { // Exception not caught } } }</code>
이 문제를 해결하려면 람다 식을 이스케이프하기 전에 예외를 캡처해야 합니다. 이는 확인된 예외를 확인되지 않은 예외로 변환하는 사용자 정의 함수에 람다를 래핑하여 달성할 수 있습니다.
<code class="java">s = s.filter(a -> { try { return a.isActive(); } catch (IOException e) { throw new UncheckedIOException(e); // Translated to an unchecked exception } });</code>
또는 래핑을 피하는 접근 방식을 사용할 수도 있습니다.
<code class="java">public static <T> T uncheckCall(Callable<T> callable) { try { return callable.call(); } catch (Exception e) { sneakyThrow(e); // Potentially throws the exception return null; // Unreachable, but necessary to satisfy the compiler } }</code>
이 함수는 본질적으로 검사된 예외가 발생할 수 없다고 믿도록 컴파일러를 속여 예외가 더 높은 수준에서 우아하게 처리되도록 합니다.
<code class="java">return s.filter(a -> uncheckCall(a::isActive)) .map(Account::getNumber) .collect(toSet());</code>
이러한 기술을 적용하면 다음과 같은 람다 식을 활용할 수 있습니다. 확인된 예외를 선언하는 메소드를 사용하여 코드 명확성과 예외 처리 기능을 모두 보장합니다.
위 내용은 Java 8 Lambda 표현식 내에서 호출된 메서드에서 발생한 확인된 예외를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!