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

com.tangosol.util.CopyOnWriteLongArray Maven / Gradle / Ivy

There is a newer version: 24.09
Show newest version
/*
 * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
 *
 * Licensed under the Universal Permissive License v 1.0 as shown at
 * http://oss.oracle.com/licenses/upl.
 */

package com.tangosol.util;


/**
* A thread-safe variant of {@link LongArray} in which all mutating operations
* (e.g. add, set) are implemented by making a fresh copy of
* the underlying array.
* 

* Iterators over this LongArray are guaranteed to produce a safe-iteration and * not to throw ConcurrentModificationException. The iterator will not * reflect concurrent additions, removals, or changes to this array. Mutating * operations on iterators themselves (e.g. remove, setValue) * are not supported (and will throw UnsupportedOperationException). *

* Note: mutations on this LongArray are costly, but may be more * efficient than alternatives when traversal operations vastly outnumber * mutations. All mutating operations are synchronized, so concurrent mutation * can be prevented by holding synchronization on this object. *

* This data-structure is not suitable to frequent updates, or updates on large * data-sets see {@link ReadHeavyLongArray} for a more suitable alternative for * such cases. * * @since Coherence 3.7 * @author rhl 2010.09.09 */ public class CopyOnWriteLongArray extends WrapperCollections.AbstractWrapperLongArray { // ----- Constructors ------------------------------------------------- /** * Default constructor. */ public CopyOnWriteLongArray() { setDelegate(EMPTY_ARRAY); } /** * Construct a CopyOnWriteLongArray with an underlying array of the specified * type. * * @param clazz the type of the internal array; must implement LongArray * and have a public no-arg constructor * * @throws ClassCastException if the specified type does not implement * LongArray * @throws IllegalAccessException if the class or its no-arg constructor is * not accessible * @throws InstantiationException if the specified Class represents an * abstract class or interface; or if the * class does not have a no-arg constructor; * or if the instantiation fails for some * other reason. */ public CopyOnWriteLongArray(Class> clazz) throws IllegalAccessException, InstantiationException { if (!LongArray.class.isAssignableFrom(clazz)) { throw new ClassCastException(clazz.getName()); } setDelegate(clazz.newInstance()); } /** * Construct a CopyOnWriteLongArray, initialized with the contents of the * specified LongArray. * * @param array the initial LongArray */ public CopyOnWriteLongArray(LongArray array) { // copy the passed array to insure that it cannot be modified directly setDelegate(copyArray(array)); } // ----- accessors ---------------------------------------------------- /** * Return the internal LongArray. * * @return the internal LongArray */ protected LongArray delegate() { return m_arrayInternal; } /** * Set the internal LongArray. * * @param array the new internal LongArray */ protected void setDelegate(LongArray array) { m_arrayInternal = array; } // ----- helpers ------------------------------------------------------ /** * Return a shallow copy of the specified LongArray. * * @param array the array to be copied * * @return a shallow copy of the specified LongArray */ public LongArray copyArray(LongArray array) { return array.clone(); } // ----- LongArray methods -------------------------------------------- /** * {@inheritDoc} */ public synchronized V set(long lIndex, V oValue) { LongArray arrayNew = copyArray(delegate()); V oValueOld = arrayNew.set(lIndex, oValue); setDelegate(arrayNew); return oValueOld; } /** * {@inheritDoc} */ public synchronized long add(V oValue) { LongArray arrayNew = copyArray(delegate()); long lIndex = arrayNew.add(oValue); setDelegate(arrayNew); return lIndex; } /** * {@inheritDoc} */ public synchronized V remove(long lIndex) { LongArray arrayNew = copyArray(delegate()); V oValueOld = arrayNew.remove(lIndex); setDelegate(arrayNew); return oValueOld; } /** * {@inheritDoc} */ public synchronized void remove(long lIndexFrom, long lIndexTo) { LongArray arrayNew = copyArray(delegate()); arrayNew.remove(lIndexFrom, lIndexTo); setDelegate(arrayNew); } /** * {@inheritDoc} */ public synchronized void clear() { LongArray arrayNew = copyArray(delegate()); arrayNew.clear(); setDelegate(arrayNew); } /** * {@inheritDoc} */ public Iterator iterator() { return instantiateUnmodifiableIterator(delegate().iterator()); } /** * {@inheritDoc} */ public Iterator iterator(long lIndex) { return instantiateUnmodifiableIterator(delegate().iterator(lIndex)); } /** * {@inheritDoc} */ public Iterator reverseIterator() { return instantiateUnmodifiableIterator(delegate().reverseIterator()); } /** * {@inheritDoc} */ public Iterator reverseIterator(long lIndex) { return instantiateUnmodifiableIterator(delegate().reverseIterator(lIndex)); } /** * {@inheritDoc} */ public CopyOnWriteLongArray clone() { // the clone can share the same (immutable) underlying array CopyOnWriteLongArray arrayNew = new CopyOnWriteLongArray<>(); arrayNew.setDelegate(delegate()); return arrayNew; } // ----- inner class: UnmodifiableIterator ---------------------------- /** * Factory pattern: instantiate an UnmodifiableIterator. * * @param iterator the underlying iterator * * @return an UnmodifiableIterator */ public LongArray.Iterator instantiateUnmodifiableIterator( LongArray.Iterator iterator) { return new UnmodifiableIterator<>(iterator); } /** * Unmodifiable view of a LongArray.Iterator. */ public static class UnmodifiableIterator implements LongArray.Iterator { // ----- constructors --------------------------------------------- /** * Construct a wrapper for the specified Iterator. * * @param iterator the iterator to create a wrapper for */ public UnmodifiableIterator(LongArray.Iterator iterator) { m_iteratorInternal = iterator; } // ----- accessors ------------------------------------------------ /** * Return the internal Iterator. * * @return the internal Iterator */ public LongArray.Iterator getInternalIterator() { return m_iteratorInternal; } // ----- LongArray.Iterator methods ------------------------------- /** * {@inheritDoc} */ public boolean hasNext() { return getInternalIterator().hasNext(); } /** * {@inheritDoc} */ public V next() { return getInternalIterator().next(); } /** * {@inheritDoc} */ public long getIndex() { return getInternalIterator().getIndex(); } /** * {@inheritDoc} */ public V getValue() { return getInternalIterator().getValue(); } /** * {@inheritDoc} */ public V setValue(V oValue) { throw new UnsupportedOperationException(); } /** * {@inheritDoc} */ public void remove() { throw new UnsupportedOperationException(); } // ----- data members --------------------------------------------- /** * The internal Iterator */ protected LongArray.Iterator m_iteratorInternal; } // ----- constants and data members ----------------------------------- /** * An empty placeholder array. This array should not be mutated or exposed. */ protected static final LongArray EMPTY_ARRAY = new SparseArray(); /** * The internal LongArray. */ private volatile LongArray m_arrayInternal; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy