Package com.tangosol.util
Class LiteSet<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractSet<E>
com.tangosol.util.LiteSet<E>
- All Implemented Interfaces:
- ExternalizableLite,- Externalizable,- Serializable,- Cloneable,- Iterable<E>,- Collection<E>,- Set<E>
public class LiteSet<E>
extends AbstractSet<E>
implements Cloneable, Externalizable, ExternalizableLite
An implementation of java.util.Set that is optimal (in terms of both size
 and speed) for very small sets of data but still works excellently with
 large sets of data.  This implementation is not thread-safe.
 
The LiteSet implementation switches at runtime between several different sub-implementations for storing the set of objects, described here:
- "empty set" - a set that contains no data;
- "single entry" - a reference directly to an item is used to represent a set with exactly one item in it;
- "Object[]" - a reference is held to an array of Objects that store the contents of the Set; the item limit for this implementation is determined by the THRESHOLD constant;
- "delegation" - for more than THRESHOLD items, a set is created to
     delegate the set management to; sub-classes can override the default
     delegation class (java.util.HashSet) by overriding the factory method
     instantiateSet().
The LiteSet implementation supports the null value.
- Author:
- cp 06/02/99
- See Also:
- 
Constructor SummaryConstructorsConstructorDescriptionLiteSet()Construct a LiteSetLiteSet(Collection<? extends E> collection) Construct a LiteSet containing the elements of the passed Collection.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanEnsures that this Set contains the specified element.booleanaddAll(Collection<? extends E> collection) Adds all of the elements in the specified Collection to this Set if they are not already present.protected voidAfter a mutation operation has reduced the size of an underlying Set, check if the delegation model should be replaced with a more size- efficient storage approach, and switch accordingly.voidclear()Removes all of the elements from this Set.clone()Create a clone of this Set.booleanReturns true if this Set contains the specified element.booleancontainsAll(Collection<?> collection) Returns true if this Set contains all of the elements in the specified Collection.elements()Returns an Enumerator over the elements in this Set.protected voidinitFromArray(Object[] ao, int c) Initialize the contents of this Set from the passed array ao containing c values.(Factory pattern) Instantiate a Set object to store items in once the "lite" threshold has been exceeded.booleanisEmpty()Determine if this Set is empty.iterator()Returns an Iterator over the elements in this Set.voidRestore the contents of this object by loading the object's state from the passed DataInput object.voidInitialize this object from the data in the passed ObjectInput stream.booleanRemoves the specified element from this Set if it is present.booleanremoveAll(Collection<?> collection) Removes from this Set all of its elements that are contained in the specified Collection.booleanretainAll(Collection<?> collection) Retains only the elements in this Set that are contained in the specified Collection.intsize()Returns the number of elements in this Set (its cardinality).Object[]toArray()Returns an array containing all of the elements in this Set.Object[]Returns an array (whose runtime type is that of the specified array) containing all of the elements in this Set.voidwriteExternal(DataOutput out) Save the contents of this object by storing the object's state into the passed DataOutput object.voidWrite this object's data to the passed ObjectOutput stream.Methods inherited from class java.util.AbstractSetequals, hashCodeMethods inherited from class java.util.AbstractCollectiontoStringMethods inherited from class java.lang.Objectfinalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.util.CollectionparallelStream, removeIf, stream, toArrayMethods inherited from interface java.util.Setspliterator
- 
Constructor Details- 
LiteSetpublic LiteSet()Construct a LiteSet
- 
LiteSetConstruct a LiteSet containing the elements of the passed Collection.- Parameters:
- collection- a Collection
 
 
- 
- 
Method Details- 
isEmptypublic boolean isEmpty()Determine if this Set is empty.- Specified by:
- isEmptyin interface- Collection<E>
- Specified by:
- isEmptyin interface- Set<E>
- Overrides:
- isEmptyin class- AbstractCollection<E>
- Returns:
- true iff this Set is empty
 
- 
sizepublic int size()Returns the number of elements in this Set (its cardinality).- Specified by:
- sizein interface- Collection<E>
- Specified by:
- sizein interface- Set<E>
- Specified by:
- sizein class- AbstractCollection<E>
- Returns:
- the number of elements in this Set
 
- 
containsReturns true if this Set contains the specified element. More formally, returns true if and only if this Set contains an elementesuch that(o==null ? e==null : o.equals(e)).- Specified by:
- containsin interface- Collection<E>
- Specified by:
- containsin interface- Set<E>
- Overrides:
- containsin class- AbstractCollection<E>
- Parameters:
- o- the object to check for
- Returns:
- true if this Set contains the specified element
 
- 
iteratorReturns an Iterator over the elements in this Set. The elements are returned in an arbitrary order.
- 
elementsReturns an Enumerator over the elements in this Set. The elements are returned in an arbitrary order.- Returns:
- an Enumerator over the elements in this Set
 
- 
toArrayReturns an array containing all of the elements in this Set. Obeys the general contract of the Set.toArray method.- Specified by:
- toArrayin interface- Collection<E>
- Specified by:
- toArrayin interface- Set<E>
- Overrides:
- toArrayin class- AbstractCollection<E>
- Returns:
- an array containing all of the elements in this Set
 
- 
toArrayReturns an array (whose runtime type is that of the specified array) containing all of the elements in this Set. Obeys the general contract of the Set.toArray(Object[]) method.- Specified by:
- toArrayin interface- Collection<E>
- Specified by:
- toArrayin interface- Set<E>
- Overrides:
- toArrayin class- AbstractCollection<E>
- Parameters:
- aDest- the array into which the elements of this Set are to be stored, if it is big enough; otherwise, a new array of the same runtime type is allocated for this purpose
- Returns:
- an array containing the elements of this Set
- Throws:
- ArrayStoreException- if the component type of aDest is not a supertype of the type of every element in this Set
 
- 
addEnsures that this Set contains the specified element. Returns true if the Set changed as a result of the call. (Returns false if this Set already contains the specified element.)- Specified by:
- addin interface- Collection<E>
- Specified by:
- addin interface- Set<E>
- Overrides:
- addin class- AbstractCollection<E>
- Parameters:
- o- element to be added to this Set
- Returns:
- true if this Set did not already contain the specified element
 
- 
removeRemoves the specified element from this Set if it is present. More formally, removes an elementesuch that(o==null ? e==null : o.equals(e)), if the Set contains such an element. Returns true if the Set contained the specified element (or equivalently, if the Set changed as a result of the call). The Set will not contain the specified element once the call returns.- Specified by:
- removein interface- Collection<E>
- Specified by:
- removein interface- Set<E>
- Overrides:
- removein class- AbstractCollection<E>
- Parameters:
- o- object to be removed from this Set, if present
- Returns:
- true if the Set contained the specified element
 
- 
containsAllReturns true if this Set contains all of the elements in the specified Collection.- Specified by:
- containsAllin interface- Collection<E>
- Specified by:
- containsAllin interface- Set<E>
- Overrides:
- containsAllin class- AbstractCollection<E>
- Parameters:
- collection- Collection to be checked for containment in this Set
- Returns:
- true if this Set contains all of the elements in the specified Collection
 
- 
addAllAdds all of the elements in the specified Collection to this Set if they are not already present. If the specified Collection is also a Set, the addAll operation effectively modifies this Set so that its value is the union of the two Sets.- Specified by:
- addAllin interface- Collection<E>
- Specified by:
- addAllin interface- Set<E>
- Overrides:
- addAllin class- AbstractCollection<E>
- Parameters:
- collection- Collection whose elements are to be added to this Set
- Returns:
- true if this Set changed as a result of the call
 
- 
retainAllRetains only the elements in this Set that are contained in the specified Collection. In other words, removes from this Set all of its elements that are not contained in the specified Collection. If the specified Collection is also a Set, this operation effectively modifies this Set so that its value is the intersection of the two Sets.- Specified by:
- retainAllin interface- Collection<E>
- Specified by:
- retainAllin interface- Set<E>
- Overrides:
- retainAllin class- AbstractCollection<E>
- Parameters:
- collection- collection that defines which elements this Set will retain
- Returns:
- true if this Set changed as a result of the call
 
- 
removeAllRemoves from this Set all of its elements that are contained in the specified Collection. If the specified Collection is also a Set, this operation effectively modifies this Set so that its value is the asymmetric set difference of the two Sets.- Specified by:
- removeAllin interface- Collection<E>
- Specified by:
- removeAllin interface- Set<E>
- Overrides:
- removeAllin class- AbstractSet<E>
- Parameters:
- collection- Collection that defines which elements will be removed from this Set
- Returns:
- true if this Set changed as a result of the call
 
- 
clearpublic void clear()Removes all of the elements from this Set. This Set will be empty after this call returns.- Specified by:
- clearin interface- Collection<E>
- Specified by:
- clearin interface- Set<E>
- Overrides:
- clearin class- AbstractCollection<E>
 
- 
cloneCreate a clone of this Set.
- 
readExternalInitialize this object from the data in the passed ObjectInput stream.- Specified by:
- readExternalin interface- Externalizable
- Parameters:
- in- the stream to read data from in order to restore the object
- Throws:
- IOException- if an I/O exception occurs
- ClassNotFoundException
 
- 
writeExternalWrite this object's data to the passed ObjectOutput stream.- Specified by:
- writeExternalin interface- Externalizable
- Parameters:
- out- the stream to write the object to
- Throws:
- IOException- if an I/O exception occurs
 
- 
readExternalRestore the contents of this object by loading the object's state from the passed DataInput object.- Specified by:
- readExternalin interface- ExternalizableLite
- Parameters:
- in- the DataInput stream to read data from in order to restore the state of this object
- Throws:
- IOException- if an I/O exception occurs
 
- 
writeExternalSave the contents of this object by storing the object's state into the passed DataOutput object.- Specified by:
- writeExternalin interface- ExternalizableLite
- Parameters:
- out- the DataOutput stream to write the state of this object to
- Throws:
- IOException- if an I/O exception occurs
 
- 
instantiateSet(Factory pattern) Instantiate a Set object to store items in once the "lite" threshold has been exceeded. This method permits inheriting classes to easily override the choice of the Set object.- Returns:
- an instance of Set
 
- 
initFromArrayInitialize the contents of this Set from the passed array ao containing c values.- Parameters:
- ao- the array that contains the values to place in this Set
- c- the number of values that will be placed into this Set
 
- 
checkShrinkFromOtherprotected void checkShrinkFromOther()After a mutation operation has reduced the size of an underlying Set, check if the delegation model should be replaced with a more size- efficient storage approach, and switch accordingly.
 
-