Guava의 MapMaker 및 CacheBuilder는 Java 지도에서 만료되는 키 관리를 어떻게 단순화할 수 있습니까?
Nov 20, 2024 pm 06:48 PMJava 맵에서 만료되는 키 관리
Java 개발자로서 키 만료 메커니즘을 처리하는 것은 종종 번거로운 작업일 수 있습니다. 많은 사람들은 수동으로 제거할 필요가 없고 코드 기반 구현에만 의존하는 간단한 솔루션을 찾고 있습니다. 이러한 문제를 완화하려면 Google 컬렉션 라이브러리(현 Guava)를 살펴보는 것이 좋습니다.
MapMaker 및 CacheBuilder 소개
Guava는 시간 기반 관리를 위한 두 가지 강력한 도구를 제공합니다. 지도: MapMaker 및 CacheBuilder. MapMaker를 사용하면 항목의 만료 시간을 설정하는 기능을 포함하여 지도를 유연하게 사용자 정의할 수 있습니다. Guava 10.0에 도입된 CacheBuilder는 캐싱 메커니즘 구성을 위한 현대화된 인터페이스를 제공합니다.
만료 기간 설정
맵 항목의 만료 기간을 구성하려면 다음을 사용할 수 있습니다. 방법:
- MapMaker: 만료(장기, TimeUnit 단위)
- CacheBuilder:expirAfterWrite(장기, TimeUnit 단위) 또는 만료AfterAccess(긴 기간, TimeUnit 단위)
MapMaker를 사용한 구현 예
ConcurrentMap<Key, Graph> graphs = new MapMaker() .concurrencyLevel(4) .softKeys() .weakValues() .maximumSize(10000) .expiration(10, TimeUnit.MINUTES) .makeComputingMap( new Function<Key, Graph>() { public Graph apply(Key key) { return createExpensiveGraph(key); } });
Guava 10.0의 개선 사항
Guava 10.0에서는, 원래 MapMaker 메소드는 더 이상 사용되지 않습니다. 캐시빌더. 다음 예에서는 CacheBuilder의 사용법을 보여줍니다.
LoadingCache<Key, Graph> graphs = CacheBuilder.newBuilder() .maximumSize(10000) .expireAfterWrite(10, TimeUnit.MINUTES) .build( new CacheLoader<Key, Graph>() { public Graph load(Key key) throws AnyException { return createExpensiveGraph(key); } });
이러한 도구를 활용하면 Java에서 시간 기반 맵을 손쉽게 관리하여 만료된 키를 자동으로 제거하고 데이터 처리 메커니즘의 효율성을 최적화할 수 있습니다.
위 내용은 Guava의 MapMaker 및 CacheBuilder는 Java 지도에서 만료되는 키 관리를 어떻게 단순화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?

2025 년 상위 4 개의 JavaScript 프레임 워크 : React, Angular, Vue, Svelte

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?

고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?

Spring Boot Snakeyaml 2.0 CVE-2022-1471 문제 고정
