언어/JAVA

[Effective Java] 다 쓴 객체 참조를 해제하라

2020. 3. 12. 21:09
반응형

아이템 7 : 다 쓴 객체 참조를 해제하라

 

가비지 컬렉션 언어에서는 의도치 않게 객체를 살려두는 메모리 누수를 찾기가 아주 까다롭다. 객체 참조 하나를 살려두면 가비지 컬렉터는 그 객체뿐 아니라 그 객체가 참조하는 모든 객체(그리고 또 그 객체들이 참조하는 모든 객체...)를 회수해가지 못한다. 그래서 단 몇개의 객체가 매우 많은 객체를 회수되지 못하게 할 수 있고 잠재적으로 성능에 악영향을 줄 수 있다.

 

해법은 간단하다. 해당 참조를 다 썼을 때 null 처리(참조 해제)하면 된다.

 

다 쓴 참조를 null 처리하면 다른 이점도 따라온다. 만약 null 처리한 참조를 실수로 사용하려 하면 프로그램은 즉시 NullPointerException을 던지며 종료된다.

 

단, 객체 참조를 null 처리하는 일은 예외적인 경우여야 한다. 다 쓴 참조를 해제하는 가장 좋은 방법은 그 참조를 담은 변수를 유효 범위 밖으로 밀어내는 것이다.

 

자기 메모리를 직접 관리하는 클래스라면 프로그래머는 항시 메모리 누수에 주의해야 한다. 원소를 다 사용한 즉시 그 원소가 참조한 객체들을 다 null 처리해줘야 한다.

 

캐시 역시 메모리 누수를 일으키는 주범이다.

 

또한, 리스너 혹은 콜백이라 부르는 것이 메모리 누수의 주범이 될 수도 있다.

클라이언트가 콜백을 등록만 하고 명확히 해지하지 않는다면, 뭔가 조치해주지 않는 한 콜백은 계속 쌓여갈 것이다. 이럴 때 콜백을 약한 참조로 저장하면 가비지 컬렉터가 즉시 수거해간다.

 

핵심 정리

메모리 누수는 겉으로 잘 드러나지 않아 시스템에 수년간 잠복하는 사례도 있다. 이런 누수는 철저한 코드 리뷰나 힙 프로파일러 같은 디버깅 도구를 동원해야만 발견되기도 한다. 그래서 이런 종류의 문제는 예방법을 익혀두는 것이 매우 중요하다.

반응형

'언어 > JAVA' 카테고리의 다른 글

[Effective Java] try-finally보다는 try-with-resources를 사용하라  (0) 2020.03.13
[Effective Java] finalizer와 cleaner 사용을 피하라  (0) 2020.03.12
[Effective Java] 불필요한 객체 생성을 피하라  (0) 2020.03.11
[Effective Java] 자원을 직접 명시하지 말고 의존 객체 주입을 사용하라  (0) 2020.03.11
[Effective Java] 인스턴스화를 막으려거든 private 생성자를 사용하라  (0) 2020.03.10
'언어/JAVA' 카테고리의 다른 글
  • [Effective Java] try-finally보다는 try-with-resources를 사용하라
  • [Effective Java] finalizer와 cleaner 사용을 피하라
  • [Effective Java] 불필요한 객체 생성을 피하라
  • [Effective Java] 자원을 직접 명시하지 말고 의존 객체 주입을 사용하라
지나가던 개발자
지나가던 개발자
지나가던 개발자
나의 발전을 위한 공간
지나가던 개발자
전체
오늘
어제
  • 분류 전체보기 (221)
    • 언어 (86)
      • C++ (43)
      • JAVA (43)
    • 게임 개발 (4)
      • 간단한 RPG 게임 만들기 (4)
      • 게임 개발 이슈 해결 (0)
    • 백준 문제풀이 (36)
      • PLATINUM (0)
      • GOLD (13)
      • SILVER (21)
      • BRONZE (2)
    • 프로그래머스 문제풀이 (32)
      • LEVEL 5 (0)
      • LEVEL 4 (0)
      • LEVEL 3 (7)
      • LEVEL 2 (19)
      • LEVEL 1 (6)
    • SQL 문제풀이 (15)
      • 프로그래머스 (4)
      • 해커랭크 (11)
    • 디자인 패턴 (1)
    • 웹 (17)
      • 웹 이론 정리 (17)
    • CS 지식 (28)
      • 알고리즘 (0)
      • 데이터베이스 (11)
      • 자료구조 (0)
      • 네트워크 (7)
      • 그래픽스 (0)
      • 운영체제 (9)
      • 기타 (1)
    • Git (1)

블로그 메뉴

  • 홈
  • 태그
  • 방명록
  • 깃 허브

공지사항

인기 글

태그

  • Chapter 4
  • 클래스와 인터페이스
  • level 1
  • Gold 5
  • mysql
  • 프로그래머스
  • 해커랭크
  • 백준
  • c++
  • BOJ
  • Silver 3
  • Level 2
  • java
  • 객체 지향 설계
  • 소멸자 및 대입 연산자
  • 객체 생성과 파괴
  • 설계 및 선언
  • 상속
  • Chapter 6
  • 열거 타입과 애너테이션

최근 댓글

최근 글

hELLO · Designed By 정상우.
지나가던 개발자
[Effective Java] 다 쓴 객체 참조를 해제하라
상단으로

티스토리툴바

개인정보

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

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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