검사 예외의 장단점
장점
- 검사 예외는 발생한 문제를 프로그래머가 처리하여 안정성을 높일 수 있게 도와준다.
단점
- 검사 예외를 사용하면 API 사용자는 catch 블록을 두어 예외를 처리하는 코드를 작성해야 하기 때문에 오히려 쓰기 불편한 API가 된다.
- 검사 예외를 던지는 메서드는 스트림 안에서 직접 사용할 수 없다.
비검사 예외를 사용하자
API를 제대로 사용해도 발생할 수 있는 예외이거나, 프로그래머가 의미 있는 조치를 취할 수 있는 경우가 아니라면 비검사 예외를 사용하자. 특히 메서드가 단 하나의 검사 예외만 던질 때는 예외 하나 때문에 try-catch문을 사용해야 하므로 더욱 더 신경쓰자.
검사 예외를 회피하는 방법
- 적절한 결과 타입을 담은 옵셔널을 반환한다.
- 검사 예외 대신 단순히 빈 옵셔널을 반환한다.
- 예외가 발생한 이유를 알려주는 부가 정보를 담을 수 없다는 단점이 있다.
- 검사 예외를 던지는 메서드를 두개로 쪼개 비검사 예외로 바꾼다.
- 이 방법처럼 상태 검사 메서드(actionPermiited)를 사용하는 경우에는 쓰레드가 동시에 접근할 수 있거나 외부 여인에 의해 상태가 변할 수 있는지 조심해야 한다.
// 리팩토링 전
try {
obj.action(args)
} catch (TheCheckedException e) {
... // 예외 상황에 대처한다.
}
// 리팩토링 후
if(obj.actionPermitted(args)) {
obj.action(args);
} else {
// 예외 상황에 대처한다.
}