Java의 가장 중요한 장점 중 하나는 메모리 관리 메커니즘입니다. 객체를 생성하기만 하면 Java 가비지 수집 메커니즘이 메모리를 신중하게 할당하고 해제합니다. 하지만 Java 애플리케이션에서는 메모리 누수가 자주 발생하기 때문에 그렇게 간단하지는 않습니다.
이 튜토리얼에서는 메모리 누수가 무엇인지, 왜 발생하는지, 방지하는 방법에 대해 설명합니다.
1. 메모리 누수란 무엇인가요?
메모리 누수의 정의: 객체는 더 이상 애플리케이션에서 사용되지 않지만 참조되고 있기 때문에 가비지 수집기가 해당 객체를 제거할 수 없습니다.
이 정의를 이해하려면 메모리에 있는 개체의 상태를 이해해야 합니다. 참조되지 않은 개체는 가비지 수집기에 의해 재활용되지만 참조된 개체는 재활용되지 않습니다. 참조되지 않은 개체는 다른 개체가 참조하지 않으므로 사용되지 않습니다. 그러나 사용되지 않은 개체가 반드시 참조되지 않는 것은 아니며 일부 개체는 참조됩니다. 이것이 메모리 누수의 원인입니다.
2. 메모리 누수는 왜 발생하나요?
다음 예시를 통해 메모리 누수가 발생하는 이유를 살펴보겠습니다. 이 예에서 개체 A는 개체 B를 참조합니다. A의 수명주기(t1-t4)는 B의 수명주기(t2-t3)보다 훨씬 깁니다. B가 애플리케이션에서 더 이상 사용되지 않는 경우에도 A는 B에 대한 참조를 계속 유지합니다. 이러한 방식으로 가비지 수집기는 B를 메모리에서 제거할 수 없습니다. A가 더 많은 개체에 대해 동일한 작업을 수행하면 메모리에 재활용할 수 없는 개체가 많아 메모리 공간을 극도로 소모하게 되므로 메모리 부족 문제가 발생할 수 있습니다.
B가 다른 객체에 대한 많은 참조를 보유하고 있을 수도 있으며, B가 참조하는 이러한 객체는 재활용될 수 없습니다. 이러한 사용되지 않은 모든 개체는 귀중한 메모리 공간을 소비합니다.
3. 메모리 누수를 방지하는 방법은 무엇인가요?
다음은 메모리 누수를 막기 위한 몇 가지 간단한 실습 팁입니다.
(1) HashMap, ArrayList 등 컬렉션 클래스에 주의하세요. 메모리 누수가 자주 발생하는 곳이기 때문입니다. 정적으로 선언되면 수명은 애플리케이션의 수명만큼 길어집니다.
(2) 이벤트 리스너와 콜백에 주의하세요. 리스너가 등록되어 있지만 클래스가 더 이상 사용되지 않을 때 등록이 취소되지 않으면 메모리 누수가 발생합니다.
(3) "클래스가 자체 메모리를 관리하는 경우 프로그래머는 메모리 누수에 주의해야 합니다." [1] 객체의 멤버 변수가 다른 객체를 가리키는 경우에는 더 이상 필요하지 않습니다. 더 이상 사용되지 않습니다.
4. 짧은 퀴즈: JDK6에서 substring() 메서드가 메모리 누수를 일으키는 이유는 무엇입니까?
이 질문에 답하려면 JDK6 및 7의 substring()에 대해 읽어보세요.
참고 자료:
[1]Bloch, Joshua.Effective Java.Addison-Wesley Professional, 2008
[2]IBM Developer Work.http://www.ibm.com/developerworks/ library /j-leaks/