책/Effective Java

[이펙티브 자바] 아이템9: try-finally보다는 try-with-resources를 사용하라

2022. 4. 20. 22:34
목차
  1. 선결론
  2. 기존의 try-finally
  3. try-with-resources 적용하기
본문은 Effective Java를 읽고 간단하게 정리한 글입니다. 필요에 따라 생략/수정된 부분이 있을 수 있으며, 내용이 추후 변경될 수 있습니다.

 

선결론

  • 자바의 라이브러리에는 close 메서드를 호출해서 사용자가 직접 닫아줘야 하는 자원이 많다
    • InputStream, OutputStream, java.sql.Connection
  • 기존에는 try-finally가 많이 쓰였지만, 많은 문제가 있었다
  • 따라서 자바7부터 새롭게 등장한 try-with-resources를 사용하자

 

 

기존의 try-finally

아래는 기존의 try-finally를 이용해 직접 자원을 닫는 예제다

public class Item9 {

    public static void main(String[] args) {
        Connection connection = new Connection();
        try {
            connection.getConnection();
        } finally {
            connection.close();
        }
    }
}


class Connection {

    public void getConnection() {
        System.out.println("Get Connection");
    }

    public void close() {
        System.out.println("Close Connection");
    }
}

/**
 * 결과
 * Get Connection
 * Close Connection
 */

이는 복수의 자원을 사용하는 경우에 두 가지 문제를 가진다

  • 중첩된 try-finally 블럭의 사용으로 인해 가독성을 크게 저해한다
  • 디버깅을 어렵게 만든다

 

위의 문제 중 '디버깅을 어렵게 만든다'라는 문제를 좀 더 살펴보자

이번엔 코드를 수정해서 getConnection() 메서드와 close() 메서드가 예외를 반환하도록 했다

public class Item9 {

    public static void main(String[] args) {
        Connection connection = new Connection();
        try {
            connection.getConnection();
        } finally {
            connection.close(); // 여기서 발생한 예외만 출력됨
        }
    }
}

class Connection {

    public void getConnection() {
        System.out.println("Get Connection");
        throw new FirstException();
    }

    public void close() {
        System.out.println("Close Connection");
        throw new SecondException();
    }
}


/**
 * 결과
 * Exception in thread "main" Get Connection
 * item9.SecondException
 * 	at item9.Connection.close(Item9.java:41)
 * 	at item9.Item9.main(Item9.java:10)
 * Close Connection
 */
  • 두 번째 예외만 출력되고 첫 번째 예외는 출력되지 않는다
    • 이것이 바로 책에서 말하는 "두 번째 예외가 첫 번째 예외를 집어삼키는 상황"이다
  • 한 개의 자원을 사용했음에도 이러한 문제가 발생했다 -> 매우 많은 자원을 사용한다면 엄청나게 복잡한 문제가 발생할 것이다

 

try-with-resources 적용하기

try-with-resources 구조를 사용하려면 해당 자원이 AutoCloseable 인터페이스를 구현하면 된다

AutoCloseable 인터페이스는 close 메서드 하나만 정의된 인터페이스다

public class Item9 {

    public static void main(String[] args) {
        try (Connection connection = new Connection()) {
            connection.getConnection(); // 둘 다 출력됨
        }
    }
}


class Connection implements AutoCloseable{

    public void getConnection() {
        System.out.println("Get Connection");
        throw new FirstException();
    }

    @Override
    public void close() {
        System.out.println("Close Connection");
        throw new SecondException();
    }
}


/**
 * 결과
 * Exception in thread "main" Get Connection
 * item9.FirstException
 * Close Connection
 * 	at item9.Connection.getConnection(Item9.java:36)
 * 	at item9.Item9.main(Item9.java:7)
 * 	Suppressed: item9.SecondException
 * 		at item9.Connection.close(Item9.java:42)
 * 		at item9.Item9.main(Item9.java:6)
 */
  • 불필요한 finally문이 제거되어 코드가 더욱 간결해졌다
  • FirstException과 SecondException이 모두 출력되었다
    • 특히, FirstException이 먼저 출력되고 SecondException은 Suppressed문과 함께 출력되어 디버깅이 편해졌다

 

try-with-resources는 복수의 자원을 사용할 때도 사용이 가능하다

이때 try-with-resources의 장점이 더욱 잘 나타난다

public class Item9 {

    public static void main(String[] args) {
        try (
                Connection connection1 = new Connection();
                Connection connection2 = new Connection();
        ) {
            connection1.getConnection();
            connection2.getConnection();
        }
    }
}
저작자표시 비영리 (새창열림)

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

[이펙티브 자바] 아이템11: equals를 재정의하려거든 hashCode도 재정의하라  (0) 2022.04.22
[이펙티브 자바] 아이템10: equals는 일반 규약을 지켜 재정의하라  (0) 2022.04.20
[이펙티브 자바] 아이템7: 다 쓴 객체 참조를 해제하라  (0) 2022.04.19
[이펙티브 자바] 아이템6: 불필요한 객체 생성을 피하라  (0) 2022.04.18
[이펙티브 자바] 아이템5: 자원을 직접 명시하지 말고 의존 객체 주입을 사용하라  (0) 2022.04.18
  1. 선결론
  2. 기존의 try-finally
  3. try-with-resources 적용하기
'책/Effective Java' 카테고리의 다른 글
  • [이펙티브 자바] 아이템11: equals를 재정의하려거든 hashCode도 재정의하라
  • [이펙티브 자바] 아이템10: equals는 일반 규약을 지켜 재정의하라
  • [이펙티브 자바] 아이템7: 다 쓴 객체 참조를 해제하라
  • [이펙티브 자바] 아이템6: 불필요한 객체 생성을 피하라
코택
코택
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
  • dp
  • 깊이 우선 탐색
  • http
  • 그래프
  • 백준
  • fastapi
  • Shortest Path
  • 파이썬
  • atdd
  • Git
  • 장고
  • mysql

최근 댓글

최근 글

hELLO · Designed By 정상우.
코택
[이펙티브 자바] 아이템9: try-finally보다는 try-with-resources를 사용하라
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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