Untitled

자바의 오류는 크게 3가지로 나눌 수 있습니다.

특징

예외에는 2가지로 나눌 수 있습니다.


요약

CheckedException: 예외처리를 확인하는 Exception 클래스들 UncheckException: 컴파일러가 예외처리를 확인하지 않는 RuntimeException 클래스들

체크 예외(CheckedException)

**반드시 예외 처리를 해야하는 특징(try/catch or throw)**을 가지고 있습니다.

실행하기 전에 예측 가능한 예외 → 복구가 가능한 예외들이기 때문에 반드시 예외를 처리하는 코드를 작성해야한다.

예시

언체크 예외(UncheckedException)

체크 예외와는 달리 예외 처리를 강제하지 않습니다.

실행 중에(Runtime) 발생할 수 있는 예외를 의미합니다.

실행하고 난 후에 알 수 있는 예외 → 명시적으로 예외처리를 강제하지 않음

프로그램에 오류가 있을 때 발생하도록 의도된 것이다.

예시

특징

주의: 이 항목은 스프링 프레임워크에서의 RuntimeException에서 기본값으로 두었을 때만 해당됩니다.

중요한 점은 Rollback의 여부입니다.

활용

CheckedException vs UncheckedException 선택하기

면접 질문

Error와 Exception의 차이를 설명해주세요.

CheckedException과 UncheckedException의 차이를 설명해주세요.

예외 상황이 발생했을 때, 위의 개념을 이용하여 예외를 처리하는 적절한 방식에 대해 설명해주세요.

  1. 무책임하게 상위 메서드에 throw로 예외를 던지는 것은 상위 메서드의 책임이 증가하기 때문에 좋지 않은 방법이다.
  2. 따라서 예외 복구 전략이 명확하고 복구가 가능하다면 Checked Excetpion을 try-catch로 잡아서 예외를 복구하는 것이 좋습니다.
  3. 복구가 불가능한 Checked Exception이 발생하면 더 구체적인 Unchecked Exception을 발생시키고 예외에 대한 메시지를 명확하게 전달하는 것이 좋습니다.

CheckedException과 UncheckedException 발생 시 Spring에서 트랜잭션 처리는 각각 어떻게 되나요?

  1. 체크드는 롤백하지 않고
  2. 언체크드는 운영상의 이슈이므로, Spring 기본값으로 해당하는 연산을 전부 취소하고 롤백함(undo)

개발하시면서 런타임에러를 경험한 적이 있는지, 실제로 사용되고있는 서비스의 경우 어떻게 해결하셨을지 궁금합니다.

@Transactional 어노테이션과 UncheckedException의 관계는 어떻게 될까요?

  1. 트랜잭션 어노테이션은 특이하게 모든 경우의 수를 따져 try catch해서 throw 하지않으면 런타임에러가 발생되지 않아, 예외처리가 어렵다.

출처

[Java] Checked Exception vs Unchecked Exception 정리

Java 예외 - 6. checked vs unchecked exception

자바 공부를 어떻게 하길래, "언체크드 예외 발생시 트랜잭션 롤백?"

이펙티브 자바 3/E