책/Effective Java

[이펙티브 자바] 아이템 72: 표준 예외를 사용하라

2022. 7. 16. 09:23
목차
  1.  
  2. 선결론
  3. 표준 예외 재사용의 장점
  4. 재사용하기 좋은 예외들
  5. 기타 TIP
본문은 Effective Java를 읽고 간단하게 정리한 글입니다. 필요에 따라 생략/수정된 부분이 있을 수 있으며, 내용이 추후 변경될 수 있습니다.

 

선결론

  • 표준 예외를 적극적으로 재사용하라
  • 자바에는 이미 재사용하기에 좋은 예외들이 충분히 많이 존재한다.

 

 

표준 예외 재사용의 장점

  • 작성한 API가 다른 사람이 익히고 사용하기에 쉬워진다
  • 이 API를 사용한 프로그램도 낯선 예외를 사용하지 않게 되어 가독성이 향상된다
  • 예외 클래스 수가 적을 수록 메모리 사용량도 줄고 클래스를 적재하는 시간도 적게 걸린다(이미 JVM이 최적화가 너무 잘되어 있어 예외 클래스 몇개를 더 추가한다고 가시적인 성능저하가 일어나진 않을 것 같은데...)

 

 

재사용하기 좋은 예외들

1) IllegalArgumentException

  • 호출자가 인수로 부적절한 값을 넘길 때 던지는 예외

 

2) IllegalStateException

  • 대상 객체의 상태가 호출된 메서드를 수행하기에 적합하지 않을 때 주로 던지는 예외
  • 메서드가 던지는 모든 예외를 잘못된 인수나 상태로 퉁칠 수 있지만(IllegalStateException을 던지게끔), 특수한 일부는 따로 구분해서 써야 한다
    • null 값을 허용하지 않는 메서드에 null을 던지면 관례상 NullPointerException을 던진다
    • 어떤 시퀀스의 허용 범위를 넘는 값을 건넬 때도 indexOutOfBoundsException을 던진다

 

3) ConcurrentModificationException

  • 단일 스레드에서 사용하려고 설계한 객체를 여러 스레드가 동시에 수정하려 할 때 던지는 예외
  • 동시 수정을 확실히 검출할 수 있는 확실한 방법은 없으므로 문제가 생길 가능성을 알려주는 정도의 역할로 쓰인다

 

4) UnsupportedOpertionException

  • 클라이언트가 요청한 동작을 대상 객체가 지원하지 않을 때 던진다
  • 보통은 구현하려는 인터페이스의 메서드 일부를 구현할 수 없을 때 쓴다

예시 - Collections.UnmodifiableCollection

static class UnmodifiableCollection<E> implements Collection<E>, Serializable {
    
    ... // 생략 

    public boolean add(E e) {
        throw new UnsupportedOperationException();
    }

    public boolean remove(Object o) {
        throw new UnsupportedOperationException();
    }
}

 

총정리

예외 주요 쓰임
IllegalArgumentException 허용하지 않는 값이 인수로 건네졌을 떄(null은 따로 NullponterException으로 처리)
IllegalStateException 객체가 메서드를 수행하기에 적절하지 않는 상태일 때
NullPointerException null을 허용하지 않는 메서드에 null을 건넸을 때
IndexOutOfBoundsException 인덱스가 범위를 넘어섰을 때
ConcourrentModificationException 허용하지 않는 동시 수정이 발견됐을 때
UnsupportedOpertaionException 호출한 메서드를 지원하지 않을 때

 

 

기타 TIP

  • Exception, RuntimeException, Throwable, Error는 직접 재사용하지 말자
    • 이 클래스들은 추상 클래스라고 생각하라
    • 이 예외들은 다른 예외들의 상위 클래스이므로, 즉 여러 성격의 예외들을 포괄하기 때문에 안정적으로 테스트할 수 없다
  • 표준 예외를 재사용할 때는 API 문서를 참고해 예외가 던져지는 맥락을 확인하고, 이에 부합할 때 사용한다
  • 더 많은 정보를 제공하길 원한다면 표준 예외를 확장해도 좋다
    • 단, 예외는 직렬화할 수 있다는 사실을 기억하자
  • 표준 예외의 주요 쓰임이 상호 배타적이지 않으므로 재사용할 예외를 선택하기 어려울 때도 있다
    • 각 표준 예외의 용례를 잘 파악하여 적절한 예외를 선택하자
저작자표시 비영리 (새창열림)

'책 > Effective Java' 카테고리의 다른 글

[이펙티브 자바] 아이템 88: readObject 메서드는 방어적으로 작성하라  (0) 2022.07.28
[이펙티브 자바] 아이템 80: 스레드보다는 실행자, 태스크, 스트림을 애용하라  (0) 2022.07.21
[이펙티브 자바] 아이템 71: 필요 없는 검사 예외 사용은 피하라  (0) 2022.07.16
[이펙티브 자바] 아이템 70: 복구할 수 있는 상황에는 검사 예외를, 프로그래밍 오류에는 런타임 예외를 사용하라  (0) 2022.07.15
[이펙티브 자바] 아이템 69: 예외는 진짜 예외 상황에만 사용하라  (0) 2022.07.15
  1.  
  2. 선결론
  3. 표준 예외 재사용의 장점
  4. 재사용하기 좋은 예외들
  5. 기타 TIP
'책/Effective Java' 카테고리의 다른 글
  • [이펙티브 자바] 아이템 88: readObject 메서드는 방어적으로 작성하라
  • [이펙티브 자바] 아이템 80: 스레드보다는 실행자, 태스크, 스트림을 애용하라
  • [이펙티브 자바] 아이템 71: 필요 없는 검사 예외 사용은 피하라
  • [이펙티브 자바] 아이템 70: 복구할 수 있는 상황에는 검사 예외를, 프로그래밍 오류에는 런타임 예외를 사용하라
코택
코택
TaxFree코택 님의 블로그입니다.
코택
TaxFree
코택
전체
오늘
어제
  • 분류 전체보기 (369)
    • Spring (29)
      • Spring (18)
      • 스프링 핵심 원리 - 고급편 (11)
    • Spring Batch (4)
    • JPA (4)
    • CS (89)
      • 자료구조 (2)
      • 네트워크 (5)
      • 운영체제 (1)
      • 데이터베이스 (4)
      • SQL (7)
      • 알고리즘 이론 (4)
      • 알고리즘 문제 풀이 (66)
    • 웹 (28)
      • React.js (4)
      • Next.js (1)
      • Node.js (14)
      • FastAPI (4)
      • Django (5)
    • 프로그래밍 언어 (45)
      • Python (5)
      • Java + Kotlin (29)
      • JavaScript + TypeScript (11)
    • 테스트코드 (26)
      • ATDD, 클린 코드 with Spring (4)
      • 이규원의 현실 세상의 TDD: 안정감을 주는 코드.. (20)
    • 인프라 (6)
      • AWS (2)
      • Kubernetes (4)
    • 트러블슈팅 (25)
    • 책 (89)
      • Effective Java (54)
      • Effective Kotlin (14)
      • 도메인 주도 개발 시작하기: DDD 핵심 개념 정.. (11)
      • 웹 프로그래머를 위한 데이터베이스를 지탱하는 기술 (6)
      • 도메인 주도 설계 첫걸음 (4)
    • Git (10)
    • 회고 (5)
    • etc (8)

블로그 메뉴

  • 홈
  • 방명록
  • 관리
  • GitHub
  • LinkedIn

공지사항

  • 스킨 관련

인기 글

태그

  • 파이썬
  • BOJ
  • Shortest Path
  • 그래프 탐색
  • mysql
  • 그래프
  • fastapi
  • 브루트포스
  • 백준
  • dp
  • http
  • atdd
  • 깊이 우선 탐색
  • 장고
  • Git

최근 댓글

최근 글

hELLO · Designed By 정상우.
코택
[이펙티브 자바] 아이템 72: 표준 예외를 사용하라
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.