Java 8에서 람다 표현식은 메서드 참조를 표현하는 간결한 방법을 제공합니다. 그러나 확인된 예외를 발생시킬 수 있는 메서드가 발생하면 기본 람다 구문이 부족해집니다.
다음 메서드를 고려하세요.
Integer myMethod(String s) throws IOException
Function
이 문제를 해결하기 위해 다음과 같은 몇 가지 접근 방식을 사용할 수 있습니다.
1. 사용자 정의 기능 인터페이스 정의:
메서드를 제어할 수 있는 경우 확인된 예외를 선언하는 사용자 정의 기능 인터페이스를 정의하는 것이 좋습니다.
@FunctionalInterface public interface CheckedFunction<T, R> { R apply(T t) throws IOException; }
그런 다음 이 인터페이스를 다음과 같이 정의할 수 있습니다. 람다 유형으로 사용됩니다:
void foo (CheckedFunction<String, Integer> f) { ... }
2. 원래 메서드 래핑:
원래 메서드를 수정할 수 없는 경우 확인된 예외를 발생시키지 않는 새 메서드로 래핑할 수 있습니다.
public Integer myWrappedMethod(String s) { try { return myMethod(s); } catch(IOException e) { throw new UncheckedIOException(e); } }
래핑된 메서드 그런 다음 람다에서 메서드를 참조할 수 있습니다.
Function<String, Integer> f = (String t) -> myWrappedMethod(t);
3. Lambda 내에서 예외 처리:
또는 람다 자체 내에서 예외를 처리할 수 있습니다.
Function<String, Integer> f = (String t) -> { try { return myMethod(t); } catch(IOException e) { throw new UncheckedIOException(e); } };
위 내용은 Java 8에서 람다 표현식을 사용할 때 확인된 예외를 어떻게 처리할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!