베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • leetcode
    • BFS
    • 알고리즘
    • 백준
    • 토비스프링
    • dfs
    • 이펙티브자바
    • java
    • 스프링시큐리티
    • 자바
    • 스레드
    • 자바8
    • Spring
    • 데이터베이스
    • C++
    • 스프링
    • 함수형인터페이스
    • 코드업
    • 운영체제
    • jpa

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    개발서적/Effective Java

    [Effective Java] 예외는 진짜 예외 상황에만 사용하라

    2023. 6. 6. 06:40

    예외의 잘못된 사용

    다음은 예외를 잘못 사용한 예시이다.

    try {
        int i = 0;
        while(true)
            range[i++].climb();
    }catch (ArrayIndexOutOfBoundException e) {
    }

    이 코드의 문제는 다음과 같다.

    1. 전혀 객관적이지 않다. 다음과 같이 작성하면 모든 사람이 직관적으로 이해할 수 있다.
    for (Mountain m : range) 
        m.climb();
    1. 제대로 동작하지 않을 수 있다.
      • 반복문안에 잘못된 코드가 숨어져 있다면 흐름 제어에 쓰인 예외가 이 버그를 숨겨 디버깅을 더 어렵게 만든다.

    예외는 필요할 때만 사용하자

    예외는 오직 예외 상황에서만 사용해야 한다. 절대로 일상적인 제어 흐름용으로 쓰여서는 안 된다. 이 원칙은 API 설계에도 적용된다. 잘 설계된 API라면 클라이언트가 정상적인 제어 흐름에서 예외를 사용할 일이 없게 해야 한다. 예를 들어 특정 상태에서만 호출할 수 있는 '상태 의존적' 메서드를 제공하는 클래스는 '상태 검사' 메서드도 함께 제공해야 한다.

    • e.g ) Iterator 인터페이스의 next와 hasNext가 각각 상태 의존적 메서드와 상태 검사 메서드에 해당한다.
    • 나눗셈을 할 때 0으로 나누는 경우 예외가 아닌 N/A를 리턴하도록 만들 수 있다.
    public static String divide(int a, int b) {
        if (b == 0) {
            System.out.println("b는 0이 될 수 없습니다.");
            return "N/A";
        }
        return String.valueOf(a / b);
    }

    Iterator가 상태 검사 메서드를 제공함으로써 전통적인 for문의 활용도 가능하다.

    for(Iterable<Foo> i = collection.iterator(); i.hasNext(); ) {
        Foo foo = i.next();
    }

    만약 상태 검사 메서드를 제공하지 않았다면 그 일을 클라이언트가 대신해야 한다.

    try {
        Iterator<Foo> i = collection.iterator();
        while(true) {
            Foo foo = i.next();
            ...
        } catch (NoSuchElementException e) {
        }
    }

    상태 검사 메서드 대신 옵셔널을 사용하거나 null 같은 특수한 값을 반환할 수 있다. 상황에 따라서 적절한 방법을 선택하자.

    • 외부 동기화 없이 여러 스레드가 동시에 접근할 수 있거나 외부 요인으로 상태가 변할 수 있다면 옵셔널이나 특정 값을 사용한다.
      -> 상태 검사 메서드와 상태 의존적 메서드 호출 사이에 객체의 상태가 변할 수 있다.
    • 성능이 중요한 상황에서 상태 검사 메서드가 상태 의존적 메서드의 작업 일부를 중복 수행한다면 옵셔널이나 특정 값을 선택한다.
    • 다른 모든 경우엔 상태 검사 메서드 방식이 조금 더 낫다.
      -> 가독성이 더 좋고, 상태 검사 메서드 호출을 잊어버렸다면 상태 의존적 메서드가 예외를 던져 버그를 확실하게 잡아준다.
    저작자표시 비영리 변경금지 (새창열림)
      '개발서적/Effective Java' 카테고리의 다른 글
      • [Effective Java] 필요 없는 검사 예외 사용은 피하라
      • [Effective Java] 복구할 수 있는 상황에는 검사 예외를, 프로그래밍 오류에는 런타임 예외를 사용하라
      • [Effective Java] 일반적으로 통용되는 명명 규칙을 따르라
      • [Effective Java] 최적화는 신중히 하라
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바