All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.cache.support.NoOpCacheManager Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2002-2014 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.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.cache.support;

import java.util.Collection;
import java.util.Collections;
import java.util.LinkedHashSet;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;

import org.springframework.cache.Cache;
import org.springframework.cache.CacheManager;

/**
 * A basic, no operation {@link CacheManager} implementation suitable
 * for disabling caching, typically used for backing cache declarations
 * without an actual backing store.
 *
 * 

Will simply accept any items into the cache not actually storing them. * * @author Costin Leau * @author Stephane Nicoll * @since 3.1 * @see CompositeCacheManager */ public class NoOpCacheManager implements CacheManager { private final ConcurrentMap caches = new ConcurrentHashMap(16); private final Set cacheNames = new LinkedHashSet(16); /** * This implementation always returns a {@link Cache} implementation that will not store items. * Additionally, the request cache will be remembered by the manager for consistency. */ @Override public Cache getCache(String name) { Cache cache = this.caches.get(name); if (cache == null) { this.caches.putIfAbsent(name, new NoOpCache(name)); synchronized (this.cacheNames) { this.cacheNames.add(name); } } return this.caches.get(name); } /** * This implementation returns the name of the caches previously requested. */ @Override public Collection getCacheNames() { synchronized (this.cacheNames) { return Collections.unmodifiableSet(this.cacheNames); } } private static class NoOpCache implements Cache { private final String name; public NoOpCache(String name) { this.name = name; } @Override public void clear() { } @Override public void evict(Object key) { } @Override public ValueWrapper get(Object key) { return null; } @Override public T get(Object key, Class type) { return null; } @Override public String getName() { return this.name; } @Override public Object getNativeCache() { return null; } @Override public void put(Object key, Object value) { } @Override public ValueWrapper putIfAbsent(Object key, Object value) { return null; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy