From 60865eae4b48863e8f19884d0c2bd46d98ff85d4 Mon Sep 17 00:00:00 2001 From: Juergen Hoeller Date: Fri, 30 Jun 2023 10:39:53 +0200 Subject: [PATCH] Align ConcurrentMapCacheManager locking behavior with CaffeineCacheManager Closes gh-30780 --- .../cache/caffeine/CaffeineCacheManager.java | 10 ++++------ .../cache/concurrent/ConcurrentMapCacheManager.java | 10 ++-------- 2 files changed, 6 insertions(+), 14 deletions(-) diff --git a/spring-context-support/src/main/java/org/springframework/cache/caffeine/CaffeineCacheManager.java b/spring-context-support/src/main/java/org/springframework/cache/caffeine/CaffeineCacheManager.java index a09c12c99473..239a7350cdc5 100644 --- a/spring-context-support/src/main/java/org/springframework/cache/caffeine/CaffeineCacheManager.java +++ b/spring-context-support/src/main/java/org/springframework/cache/caffeine/CaffeineCacheManager.java @@ -189,13 +189,11 @@ public Collection getCacheNames() { @Override @Nullable public Cache getCache(String name) { - if (this.dynamic) { - Cache cache = this.cacheMap.get(name); - return (cache != null) ? cache : this.cacheMap.computeIfAbsent(name, this::createCaffeineCache); - } - else { - return this.cacheMap.get(name); + Cache cache = this.cacheMap.get(name); + if (cache == null && this.dynamic) { + cache = this.cacheMap.computeIfAbsent(name, this::createCaffeineCache); } + return cache; } diff --git a/spring-context/src/main/java/org/springframework/cache/concurrent/ConcurrentMapCacheManager.java b/spring-context/src/main/java/org/springframework/cache/concurrent/ConcurrentMapCacheManager.java index 8a29d1fd2900..2d993db5ba66 100644 --- a/spring-context/src/main/java/org/springframework/cache/concurrent/ConcurrentMapCacheManager.java +++ b/spring-context/src/main/java/org/springframework/cache/concurrent/ConcurrentMapCacheManager.java @@ -1,5 +1,5 @@ /* - * Copyright 2002-2021 the original author or authors. + * Copyright 2002-2023 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -165,13 +165,7 @@ public Collection getCacheNames() { public Cache getCache(String name) { Cache cache = this.cacheMap.get(name); if (cache == null && this.dynamic) { - synchronized (this.cacheMap) { - cache = this.cacheMap.get(name); - if (cache == null) { - cache = createConcurrentMapCache(name); - this.cacheMap.put(name, cache); - } - } + cache = this.cacheMap.computeIfAbsent(name, this::createConcurrentMapCache); } return cache; }