
org.infinispan.atomic.impl.AtomicHashMap Maven / Gradle / Ivy
package org.infinispan.atomic.impl;
import net.jcip.annotations.NotThreadSafe;
import org.infinispan.AdvancedCache;
import org.infinispan.Cache;
import org.infinispan.atomic.AtomicMap;
import org.infinispan.atomic.AtomicMapLookup;
import org.infinispan.atomic.CopyableDeltaAware;
import org.infinispan.atomic.Delta;
import org.infinispan.atomic.NullDelta;
import org.infinispan.commons.marshall.AbstractExternalizer;
import org.infinispan.commons.util.FastCopyHashMap;
import org.infinispan.commons.util.Util;
import org.infinispan.marshall.core.Ids;
import org.infinispan.util.logging.Log;
import org.infinispan.util.logging.LogFactory;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Collection;
import java.util.Map;
import java.util.Set;
/**
* The default implementation of {@link AtomicMap}. Note that this map cannot be constructed directly, and callers
* should obtain references to AtomicHashMaps via the {@link AtomicMapLookup} helper. This helper will ensure proper
* concurrent construction and registration of AtomicMaps in Infinispan's data container. E.g.:
*
*
* AtomicMap<String, Integer> map = AtomicMapLookup.getAtomicMap(cache, "my_atomic_map_key");
*
*
* Note that for replication to work properly, AtomicHashMap updates must always take place within the
* scope of an ongoing JTA transaction or batch (see {@link Cache#startBatch()}).
*
*
* @author (various)
* @param the type of keys maintained by this map
* @param the type of mapped values
* @see AtomicMap
* @see AtomicMapLookup
* @since 4.0
*/
@NotThreadSafe
public final class AtomicHashMap implements AtomicMap, CopyableDeltaAware, Cloneable {
private static final Log log = LogFactory.getLog(AtomicHashMap.class);
private static final boolean trace = log.isTraceEnabled();
protected final FastCopyHashMap delegate;
private AtomicHashMapDelta delta = null;
private volatile AtomicHashMapProxy proxy;
volatile boolean copied = false;
volatile boolean removed = false;
/**
* Construction only allowed through this factory method. This factory is intended for use internally by the
* CacheDelegate. User code should use {@link AtomicMapLookup#getAtomicMap(Cache, Object)}.
*/
public static AtomicHashMap newInstance(Cache
© 2015 - 2025 Weber Informatics LLC | Privacy Policy