[Effective Java] 아이템 72. 표준 예외를 사용하라

2022. 12. 13. 23:09· BE/Java
목차
  1. 아이템 72. 표준 예외를 사용하라
  2.  
반응형

EFFECTIVE JAVA(이펙티브 자바)

 

이 포스팅에서 작성하는 내용은 EFFECTIVE JAVA(이펙티브자바) 에서 발췌하였습니다.


아이템 72. 표준 예외를 사용하라

숙력된 프로그래머는 그렇지 못한 프로그래머보다 더 많은 코드를 재사용하듯, 예외도 재사용하는 것이 좋으며 자바 라이브러리는 대부분 API에서 쓰기에 충분한 수의 예외를 제공한다.

 

표준 예외

  • 표준 예외를 재사용하면 얻는 게 많다.
    • 개발자의 API가 다른 사람이 익히고 사용하기 쉬워진다. (많은 프로그래머에게 이미 익숙해진 규약을 그대로 따르기 때문)
    • 예외 클래스 수가 적을수록 메모리 사용량도 줄고 클래스를 적재하는 시간도 적게 걸린다.
  • Exception, RuntimeException, Thorwable, Error는 직접 재사용하지 말자.
    • 이 클래스들은 추상 클래스라고 생각하는 것이 편하다.
    • 이 예외들은 다른 예외들의 상위 클래스이므로, 안적정으로 테스트 할 수 없다.
  • 상황에 부합한다면 항상 표준 예외를 재사용하며, 이 때 API문서를 참고해 그 예외가 어떤 상황에서 던져지는 지 꼭 확인해야 한다.
  • 예외의 이름 뿐 아니라 예외가 던져지는 맥락도 부합할 때만 재사용한다.
  • 인수 값이 무엇이었든 어차피 실패했을 거라면 IllegalStateException을, 그렇지 않으면 IllegalArgumentException을 던지자.

 

많이 재사용되는 예외

  • IllegalArgumentException
    • 호출자가 인수로 부적절한 값을 넘길 때 던지는 예외로, 예를 들어 반복 횟수를 지정하는 매개변수에 음수를 건네는 경우이다.
  • IllegalStateException
    • 대상 객체의 상태가 호출된 메서드를 수행하기에 적합하지 않을 때 주로 던진다.
    • 제대로 초기화되지 않은 객체를 사용하려 할 때 던질 수 있다.
    • 메서드가 던지는 모든 예외를 잘못된 인수나 상태라고 생각할 수 있지만, 그 중 특수한 일부는 따로 구분하는 게 보통이다.
    • null 값을 허용하지 않는 메서드에 null을 건네면 관례상 IllegalArgumentException이 아닌 NPE를 던진다.
  • ConcurrentModificationException
    • 단일 스레드에서 사용하라고 설계한 객체를 여러 스레드가 동시에 수정하려 할 때 던진다.
    • 사실, 동시 수정을 확실히 검출할 수 있는 안정된 방법은 없으니, 이 예외가 문제가 생길 가능성을 알려주는 정도로 사용된다.
  • UnSupportedOperationException
    • 클라이언트가 요청한 동작을 대상 객체가 지원하지 않을 때 던진다.
    • 대부분 객체는 자신이 정의한 메서드를 모두 지원하니 흔히 쓰이는 예외는 아니다.
    • 보통은 구현하려는 인터페이스의 메서드 일부를 구현할 수 없을 때 쓰이는데, 예로 원소를 넣을 수만 있는 List 구현체에 누군가 remove 메서드를 호출하면 이 예외를 던지는 경우이다.

 

위의 내용을 정리한 표

IllegalArgumentException 허용하지 않는 값이 인수로 건네졌을 때 (주의* null은 따로 NullPointerException으로 처리)
IllegalStateException 객체가 메서드를 수행하기에 적절하지 않은 상태일 때
NullPointerException null을 허용하지 않는 메서드에 null을 건넸을 때
IndexOutOfBoundsException 인덱스가 범위를 넘어섰을 때
ConcurrentModificationException 허용하지 않는 동시 수정이 발견됐을 때
UnsupportedOperationException 호출한 메서드를 지원하지 않을 때
반응형

'BE > Java' 카테고리의 다른 글

[Effective Java] 아이템 74. 메서드가 던지는 모든 예외를 문서화하라  (0) 2022.12.14
[Effective Java] 아이템 73. 추상화 수준에 맞는 예외를 던지라  (0) 2022.12.14
[Effective Java] 아이템 71. 필요 없는 검사 예외 사용은 피하라  (0) 2022.12.12
[Effective Java] 아이템 70. 복구할 수 있는 상황에는 검사 예외를, 프로그래밍 오류에는 런타임 예외를 사용하라  (0) 2022.12.08
[Effective Java] 아이템 69. 예외는 진짜 예외 상황에만 사용하라  (0) 2022.12.07
  1. 아이템 72. 표준 예외를 사용하라
  2.  
'BE/Java' 카테고리의 다른 글
  • [Effective Java] 아이템 74. 메서드가 던지는 모든 예외를 문서화하라
  • [Effective Java] 아이템 73. 추상화 수준에 맞는 예외를 던지라
  • [Effective Java] 아이템 71. 필요 없는 검사 예외 사용은 피하라
  • [Effective Java] 아이템 70. 복구할 수 있는 상황에는 검사 예외를, 프로그래밍 오류에는 런타임 예외를 사용하라
멍목
멍목
개발 관련 새롭게 알게 된 지식이나 좋은 정보들을 메모하는 공간입니다.
반응형
멍목
김멍목의 개발블로그
멍목
전체
오늘
어제
  • 분류 전체보기 (514)
    • BE (190)
      • Spring (21)
      • Java (141)
      • Kotlin (6)
      • JPA (22)
    • FE (33)
      • Javascript (16)
      • Typescript (0)
      • React (5)
      • Vue.js (9)
      • JSP & JSTL (3)
    • DB (32)
      • Oracle (22)
      • MongoDB (10)
    • Algorithm (195)
    • Linux (8)
    • Git (6)
    • etc (42)
    • ---------------------------.. (0)
    • 회계 (4)
      • 전산회계 2급 (4)
    • 잡동사니 (2)

블로그 메뉴

  • 홈
  • 관리

공지사항

인기 글

태그

  • 더 자바 Java 8
  • Effective Java
  • 전산회계 2급 준비
  • 자기 공부
  • 자기 개발
  • 코틀린
  • 이펙티브자바
  • 코테 공부
  • 자바 공부
  • 더 자바 애플리케이션을 테스트하는 다양한 방법
  • JPA
  • 프로젝트로 배우는 Vue.js 3
  • Java to Kotlin
  • 자기개발
  • 자바 테스팅 프레임워크
  • java 8
  • JPA 공부
  • 알고리즘공부
  • 알고리즘 공부
  • MongoDB 공부
  • 자바공부
  • 자바 개발자를 위한 코틀린 입문
  • Oracle
  • vue3 공부
  • 이펙티브 자바
  • 자기공부
  • MongoDB with Node.js
  • junit5
  • MongoDB 기초부터 실무까지
  • 코테공부

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.0
멍목
[Effective Java] 아이템 72. 표준 예외를 사용하라
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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