>Java >java지도 시간 >Java 8 캐시 메서드 참조가 있으며 언제 캐싱을 고려해야 합니까?

Java 8 캐시 메서드 참조가 있으며 언제 캐싱을 고려해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-30 06:42:11780검색

Does Java 8 Cache Method References and When Should You Consider Caching Them?

Java 8의 메서드 참조 캐싱: 자세한 조사

소개

Java 8의 메소드 참조에서 캐싱의 잠재적 이점에 관한 질문이 발생합니다. 이 문서에서는 캐싱 메서드 참조의 의미를 살펴보고 이것이 언제 유리할 수 있는지에 대한 지침을 제공합니다.

호출 사이트 실행과 메서드 참조 실행 구별

구별하는 것이 중요합니다. 상태 비저장 또는 상태 저장 람다를 사용하여 동일한 호출 사이트를 자주 실행하는 것과 서로 다른 메서드에서 동일한 메서드에 대한 메서드 참조를 자주 사용하는 것 사이 call-sites.

예제 분석

다음 예를 고려하십시오.

Runnable r1 = null;
for (int i = 0; i < 2; i++) {
    Runnable r2 = System::gc;
    if (r1 == null) {
        r1 = r2;
    } else {
        System.out.println(r1 == r2 ? "shared" : "unshared");
    }
}

여기서 동일한 호출 사이트가 두 번 실행되어 상태 비저장 람다이며 구현 시 "shared"가 인쇄됩니다.

Runnable r1 = null;
for (int i = 0; i < 2; i++) {
    Runnable r2 = Runtime.getRuntime()::gc;
    if (r1 == null) {
        r1 = r2;
    } else {
        System.out.println(r1 == r2 ? "shared" : "unshared");
        System.out.println(r1.getClass() == r2.getClass() ? "shared class" : "unshared class");
    }
}

이 예에서는 동일한 호출 사이트가 두 번 실행되어 런타임 인스턴스에 대한 참조가 포함된 람다를 생성하며 구현에서는 "공유되지 않음"이 아닌 "공유 클래스"가 인쇄됩니다.

Runnable r1 = System::gc, r2 = System::gc;
System.out.println(r1 == r2 ? "shared" : "unshared");
System.out.println(r1.getClass() == r2.getClass() ? "shared class" : "unshared class");

반대로, 마지막 예에는 동등한 메소드 참조를 생성하는 두 개의 별도 호출 사이트가 포함되어 있지만 Java 8.0.05부터는 "unshared" 및 "unshared"가 인쇄됩니다. class."

JVM 동작

JVM(Java Virtual Machine)은 메소드 참조를 처리하는 데 중요한 역할을 합니다. 이는 LambdaMetafactory의 JRE 부트스트랩 메서드를 참조하는 Invokedynamic 명령을 사용합니다. 컴파일러는 람다 구현 클래스를 생성하는 데 필요한 인수를 제공합니다.

JVM에는 첫 번째 호출 중에 형성된 CallSite 인스턴스를 기억하고 재사용할 수 있는 유연성이 있습니다. 상태 비저장 람다 및 단일 호출 사이트의 경우 JVM은 일반적으로 상수 개체에 대한 MethodHandle로 구성된 ConstantCallSite를 생성합니다.

반면에 매개 변수(예: this::func)가 있는 람다의 경우 JVM은 다음과 같은 작업을 수행할 수 있습니다. 캐시하지만 매개변수와 람다 인스턴스 간의 맵을 유지하는 데 추가 오버헤드가 발생합니다. 현재 JVM은 이러한 람다를 캐시하지 않습니다. 이 동작은 서로 다른 호출 사이트에서 생성된 동일한 대상 메서드에 대한 메서드 참조에 유사하게 적용됩니다.

캐싱 고려 사항

앞서 언급한 사항을 기반으로 캐싱 메서드 참조는 다음을 생성할 수 있습니다. 결과는 다르지만 반드시 성능이 더 좋아지는 것은 아닙니다. 캐싱 메커니즘을 구현하기 전에 성능 영향을 측정해야 합니다. 캐싱이 도움이 될 수 있는 특정한 경우가 있습니다.

  • 여러 호출 사이트가 동일한 메소드를 참조하는 경우
  • 생성자/클래스 초기화에서 람다가 생성된 경우
  • 사용 사이트가 여러 호출에서 동시에 실행되는 경우 스레드
  • 첫 번째 람다 호출의 성능이 낮은 경우 우려 사항

결론

캐싱 방법 참조는 특정 시나리오에서 최적화 기술이 될 수 있습니다. 그러나 캐시 결정은 코드와 특정 성능 요구 사항에 대한 신중한 분석을 바탕으로 이루어져야 합니다. JVM의 메소드 참조 처리는 Java 8에서 람다 및 메소드 참조 사용을 최적화하기 위한 견고한 기반을 제공합니다.

위 내용은 Java 8 캐시 메서드 참조가 있으며 언제 캐싱을 고려해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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