이 문서에서 참조된 코드는 Epsilon GC와 관련하여 Oracle 블로그에서 사용할 수 있는 샘플 코드에서 가져온 것입니다.
이 기사에서는 Epsilon GC로 알려진 Java GC(가비지 수집)의 특히 흥미로운 옵션을 살펴보겠습니다. 이 가비지 수집 알고리즘은 가비지 수집을 수행하지 않는다는 독특한 특징으로 유명합니다. Epsilon GC(가비지 수집기)가 JDK 11에 포함되었습니다.
그런데 수집이 아닌 경우 가비지 수집기가 무슨 소용이 있나요? (프리로더죠!!)
아니요, 실제로는 꽤 유용합니다. Oracle 블로그에서 제공하는 사용 사례 중 하나로, 좀 더 유용하도록 약간 향상시켰습니다.
자세한 내용은 블로그 원문을 참고해주세요:
https://blogs.oracle.com/javamagazine/post/epsilon-the-jdks-do-nothing-garbage-collector
사용 사례: Epsilon GC는 프로파일링 도구의 도움 없이 특정 코드 세그먼트에 대한 메모리 할당을 평가해야 하는 개발자에게 유용합니다.
주요 과제기존 가비지 수집기는 지속적으로 객체를 지워 정확한 메모리 사용량 측정항목을 모호하게 만들 수 있습니다. 이러한 간섭으로 인해 코드의 실제 메모리 소비량을 확인하기가 어렵습니다.
Epsilon GC는 비수집자 역할을 하여 이 문제를 해결합니다. 가비지 수집 알고리즘 자체는 아니지만 가비지 수집을 수행하지 않음으로써 메모리 할당을 이해하는 도구 역할을 하여 메모리 사용량을 명확하게 보여줍니다.
참고: Epsilon GC는 메모리를 회수하지 않으므로 과도한 할당으로 인해 JVM에서 OutOfMemoryError(OOM)가 발생할 수 있다는 점에 유의하는 것이 중요합니다.
다음은 Epsilon GC의 효능을 입증하는 데 사용될 샘플 코드입니다.
public class EpsilonDemo { public static String formatSize(long v) { if (v < 1024) return v + " B"; int z = (63 - Long.numberOfLeadingZeros(v)) / 10; return String.format("%.1f %sB", (double)v / (1L << (z*10)), " KMGTPE".charAt(z)); } public static void printmem(){ System.out.println("*** Free MEM = "+formatSize(Runtime.getRuntime().freeMemory())); } public static void main(String[] args) { final int MEGAABYTE = 1024 * 1024; final int ITERATIONS = 80; System.out.println("Starting allocations..."); printmem(); // allocate memory 1MB at a time for (int i = 0; i < ITERATIONS; i++) { var array = new byte[MEGAABYTE]; } System.out.println("Completed successfully"); printmem(); } }
기대:
코드는 80MB의 바이트 유형 개체를 할당합니다. 코드를 실행할 때 print 문에서도 동일한 내용을 관찰할 수 있어야 합니다.
이제 EpsilonGC 유무에 관계없이 컴파일된 버전을 실행하려면:
java -Xms100m -Xmx100m -XX:+UseG1GC EpsilonDemo Starting allocations... *** Free MEM = 102.2 MB Completed successfully *** Free MEM = 74.2 MB
그래서 G1GC에서는 28MB 사용률이라는 잘못된 할당 그림이 표시됩니다
java -Xms100m -Xmx100m -XX:+UnlockExperimentalVMOptions -XX:+UseEpsilonGC EpsilonDemo [0.004s][warning][gc,init] Consider enabling -XX:+AlwaysPreTouch to avoid memory commit hiccups Starting allocations... *** Free MEM = 99.4 MB Completed successfully *** Free MEM = 18.7 MB
여기서 80.7MB의 사용률을 확실히 볼 수 있습니다
EpsilonGC가 코드에서 메모리 사용 패턴을 찾아내는 데 얼마나 편리한지 이해하는 데 도움이 되기를 바랍니다. 건배! ?
위 내용은 Java EpsilonGC를 사용하여 메모리 할당을 살펴봅니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!