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

org.infinispan.commons.api.BasicCache Maven / Gradle / Ivy

package org.infinispan.commons.api;

import java.util.Map;
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.TimeUnit;

/**
 * BasicCache provides the common building block for the two different types of caches that Infinispan provides:
 * embedded and remote.
 * 

* For convenience, BasicCache extends {@link ConcurrentMap} and implements all methods accordingly, although methods like * {@link ConcurrentMap#keySet()}, {@link ConcurrentMap#values()} and {@link ConcurrentMap#entrySet()} are expensive * (prohibitively so when using a distributed cache) and frequent use of these methods is not recommended. *

* Other methods such as {@link #size()} provide an approximation-only, and should not be relied on for an accurate picture * as to the size of the entire, distributed cache. Remote nodes are not queried and in-fly transactions are not * taken into account, even if {@link #size()} is invoked from within such a transaction. *

* Also, like many {@link ConcurrentMap} implementations, BasicCache does not support the use of null keys or * values. *

*

Unsupported operations

*

{@link #containsValue(Object)}

* * Please see the Infinispan documentation and/or the 5 Minute Usage Tutorial for more details. *

* * @author [email protected] * @author Manik Surtani * @author Galder Zamarreño * @author Tristan Tarrant * * @see org.infinispan.manager.CacheContainer * @see DefaultCacheManager * @see Infinispan documentation * @see 5 Minute Usage Tutorial * * @since 5.1 */ public interface BasicCache extends AsyncCache, ConcurrentMap, Lifecycle { /** * Retrieves the name of the cache * * @return the name of the cache */ String getName(); /** * Retrieves the version of Infinispan * * @return a version string */ String getVersion(); /** * {@inheritDoc} * * If the return value of this operation will be ignored by the application, * the user is strongly encouraged to use the {@link org.infinispan.context.Flag#IGNORE_RETURN_VALUES} * flag when invoking this method in order to make it behave as efficiently * as possible (i.e. avoiding needless remote or network calls). */ @Override V put(K key, V value); /** * An overloaded form of {@link #put(Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param unit unit of measurement for the lifespan * @return the value being replaced, or null if nothing is being replaced. */ V put(K key, V value, long lifespan, TimeUnit unit); /** * An overloaded form of {@link #putIfAbsent(Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param unit unit of measurement for the lifespan * @return the value being replaced, or null if nothing is being replaced. */ V putIfAbsent(K key, V value, long lifespan, TimeUnit unit); /** * An overloaded form of {@link #putAll(Map)}, which takes in lifespan parameters. Note that the lifespan is applied * to all mappings in the map passed in. * * @param map map containing mappings to enter * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param unit unit of measurement for the lifespan */ void putAll(Map map, long lifespan, TimeUnit unit); /** * An overloaded form of {@link #replace(Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param unit unit of measurement for the lifespan * @return the value being replaced, or null if nothing is being replaced. */ V replace(K key, V value, long lifespan, TimeUnit unit); /** * An overloaded form of {@link #replace(Object, Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param oldValue value to replace * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param unit unit of measurement for the lifespan * @return true if the value was replaced, false otherwise */ boolean replace(K key, V oldValue, V value, long lifespan, TimeUnit unit); /** * An overloaded form of {@link #put(Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param lifespanUnit time unit for lifespan * @param maxIdleTime the maximum amount of time this key is allowed to be idle for before it is considered as * expired * @param maxIdleTimeUnit time unit for max idle time * @return the value being replaced, or null if nothing is being replaced. */ V put(K key, V value, long lifespan, TimeUnit lifespanUnit, long maxIdleTime, TimeUnit maxIdleTimeUnit); /** * An overloaded form of {@link #putIfAbsent(Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param lifespanUnit time unit for lifespan * @param maxIdleTime the maximum amount of time this key is allowed to be idle for before it is considered as * expired * @param maxIdleTimeUnit time unit for max idle time * @return the value being replaced, or null if nothing is being replaced. */ V putIfAbsent(K key, V value, long lifespan, TimeUnit lifespanUnit, long maxIdleTime, TimeUnit maxIdleTimeUnit); /** * An overloaded form of {@link #putAll(Map)}, which takes in lifespan parameters. Note that the lifespan is applied * to all mappings in the map passed in. * * @param map map containing mappings to enter * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param lifespanUnit time unit for lifespan * @param maxIdleTime the maximum amount of time this key is allowed to be idle for before it is considered as * expired * @param maxIdleTimeUnit time unit for max idle time */ void putAll(Map map, long lifespan, TimeUnit lifespanUnit, long maxIdleTime, TimeUnit maxIdleTimeUnit); /** * An overloaded form of {@link #replace(Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param lifespanUnit time unit for lifespan * @param maxIdleTime the maximum amount of time this key is allowed to be idle for before it is considered as * expired * @param maxIdleTimeUnit time unit for max idle time * @return the value being replaced, or null if nothing is being replaced. */ V replace(K key, V value, long lifespan, TimeUnit lifespanUnit, long maxIdleTime, TimeUnit maxIdleTimeUnit); /** * An overloaded form of {@link #replace(Object, Object, Object)}, which takes in lifespan parameters. * * @param key key to use * @param oldValue value to replace * @param value value to store * @param lifespan lifespan of the entry. Negative values are interpreted as unlimited lifespan. * @param lifespanUnit time unit for lifespan * @param maxIdleTime the maximum amount of time this key is allowed to be idle for before it is considered as * expired * @param maxIdleTimeUnit time unit for max idle time * @return true if the value was replaced, false otherwise */ boolean replace(K key, V oldValue, V value, long lifespan, TimeUnit lifespanUnit, long maxIdleTime, TimeUnit maxIdleTimeUnit); /** * {@inheritDoc} * * If the return value of this operation will be ignored by the application, * the user is strongly encouraged to use the {@link org.infinispan.context.Flag#IGNORE_RETURN_VALUES} * flag when invoking this method in order to make it behave as efficiently * as possible (i.e. avoiding needless remote or network calls). */ @Override V remove(Object key); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy