>  기사  >  Java  >  Java EpsilonGC를 사용하여 메모리 할당을 살펴봅니다.

Java EpsilonGC를 사용하여 메모리 할당을 살펴봅니다.

WBOY
WBOY원래의
2024-09-08 16:31:33809검색

Using Java EpsilonGC to look at memory allocation.

이 문서에서 참조된 코드는 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 유무에 관계없이 컴파일된 버전을 실행하려면:

  1. G1GC와 함께 실행:
java -Xms100m -Xmx100m -XX:+UseG1GC  EpsilonDemo
Starting allocations...
*** Free MEM = 102.2 MB
Completed successfully
*** Free MEM = 74.2 MB

그래서 G1GC에서는 28MB 사용률이라는 잘못된 할당 그림이 표시됩니다

  1. EpsilonGC로 실행:
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.