Java Garbage Collector사용 팁, GC(가비지 수집기)는 최신 소프트웨어 가상 머신 기술의 중요한 부분이며 해당 디자인은 가상 머신에서 실행되는 애플리케이션의 성능에 큰 영향을 미칩니다. JVM(Java Virtual Machine)과 .net 프레임워크 모두 이 기능을 제공합니다. 아래에서는 Java 가상 머신의 가비지 컬렉터의 원리를 간략하게 소개합니다.
Java의 메모리 관리는 실제로 객체 할당 및 해제를 포함한 객체 관리입니다.
프로그래머의 경우 new 키워드를 사용하여 개체를 할당하세요. 개체를 해제할 때 개체에 대한 모든 참조를 null로 할당하세요. GC의 경우 프로그래머가 객체를 생성하면 GC는 객체의 주소, 크기 및 사용법을 모니터링하기 시작합니다. 일반적으로 GC는 방향성 그래프를 사용하여 힙의 모든 개체를 기록하고 관리합니다. 이런 방식으로 어떤 개체가 "접근 가능"하고 어떤 개체가 "접근 불가능"한지 결정됩니다. GC가 일부 개체에 "접근할 수 없음"을 확인하면 GC는 이러한 메모리 공간을 회수해야 합니다.
GC는 일반적으로 JVM의 프로세스 하나 또는 그룹에 의해 구현됩니다. 그 자체는 사용자 프로그램과 동일한 힙 공간을 차지하고 실행 시 CPU도 차지합니다. GC 프로세스가 실행되는 동안 애플리케이션 실행이 중지됩니다.
따라서 GC 실행 시간이 길면 사용자는 Java 프로그램의 일시 중지를 느낄 수 있는 반면, GC 실행 시간이 너무 짧으면 객체 재활용률이 너무 낮아질 수 있습니다. 재활용해야 할 개체가 여전히 많기 때문에 여전히 많은 메모리를 차지합니다. 따라서 GC를 설계할 때 Pause Time과 Recovery Rate 사이에서 trade-off가 이루어져야 한다.
GC의 작동 원리에 따라 몇 가지 기술과 방법을 사용하여 GC 작업을 보다 효율적이고 응용 프로그램의 요구 사항에 맞게 만들 수 있습니다.
다음은 프로그래밍에 대한 몇 가지 제안 사항입니다.
1. 가장 기본적인 제안은 쓸모없는 객체에 대한 참조를 가능한 한 빨리 해제하는 것입니다.
대부분의 프로그래머가 임시 변수를 사용할 때 활성 범위(scope)를 종료한 후 참조 변수가 자동으로 null로 설정되도록 합니다.
2. 마무리 기능을 최대한 적게 사용하세요. finalize 기능은 Java 프로그래머에게 객체나 리소스를 해제할 수 있는 기회를 제공합니다. 그러나 GC의 작업 부하가 증가하므로 리소스 복구를 위해 finalize를 최대한 적게 사용하십시오.
3. 자주 사용하는 사진을 사용해야 하는 경우 소프트 애플리케이션 유형을 사용할 수 있습니다. 프로그램이 OutOfMemory를 발생시키지 않고 호출할 수 있도록 가능한 한 많은 그림을 메모리에 저장할 수 있습니다.
4. 배열, 트리, 그래프, 연결된 목록 및 기타 데이터 구조를 포함한 컬렉션 데이터 유형에 주의하세요. 이러한 개체의 경우 GC 재활용이 일반적으로 덜 효율적입니다. 프로그램에서 허용하는 경우 사용하지 않는 참조 개체를 가능한 한 빨리 null로 설정하세요. 이렇게 하면 GC 작업 속도가 빨라질 수 있습니다. 따라서 꼭 필요한 경우가 아니라면 프로그램에 사용되는 데이터 구조는 최대한 단순해야 한다.
5. 프로그램에 특정 대기 시간이 있는 경우 프로그래머는 System.gc()를 수동으로 실행하여 GC가 실행되도록 알릴 수 있지만 Java 언어 사양은 GC가 실행된다는 것을 보장하지 않습니다.
JAVA 프로그램에서 가비지 컬렉터의 실행은 자동이며 강제할 수 없습니다. 프로그래머가 메모리 조각이 쓸모없고 재활용되어야 한다고 명확하게 판단할 수 있더라도 프로그래머는 가비지 컬렉터에게 이를 재활용하도록 강요할 수 없습니다. 메모리 블록.
위 내용은 Java에서 가비지 수집기를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!