Class CollectionBag<E>
- java.lang.Object
-
- org.apache.commons.collections4.collection.AbstractCollectionDecorator<E>
-
- org.apache.commons.collections4.bag.AbstractBagDecorator<E>
-
- org.apache.commons.collections4.bag.CollectionBag<E>
-
- Type Parameters:
E
- the type of elements in this bag
- All Implemented Interfaces:
java.io.Serializable
,java.lang.Iterable<E>
,java.util.Collection<E>
,Bag<E>
public final class CollectionBag<E> extends AbstractBagDecorator<E>
Decorates anotherBag
to comply with the Collection contract.By decorating an existing
Bag
instance with aCollectionBag
, it can be safely passed on to methods that require Collection types that are fully compliant with the Collection contract.The method javadoc highlights the differences compared to the original Bag interface.
- Since:
- 4.0
- See Also:
Bag
, Serialized Form
-
-
Constructor Summary
Constructors Constructor Description CollectionBag(Bag<E> bag)
Constructor that wraps (not copies).
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
add(E object)
(Change) Adds one copy of the specified object to the Bag.boolean
add(E object, int count)
(Change) Addscount
copies of the specified object to the Bag.boolean
addAll(java.util.Collection<? extends E> coll)
static <E> Bag<E>
collectionBag(Bag<E> bag)
Factory method to create a bag that complies to the Collection contract.boolean
containsAll(java.util.Collection<?> coll)
(Change) Returnstrue
if the bag contains all elements in the given collection, not respecting cardinality.boolean
remove(java.lang.Object object)
(Change) Removes the first occurrence of the given object from the bag.boolean
removeAll(java.util.Collection<?> coll)
(Change) Remove all elements represented in the given collection, not respecting cardinality.boolean
retainAll(java.util.Collection<?> coll)
(Change) Remove any members of the bag that are not in the given collection, not respecting cardinality.-
Methods inherited from class org.apache.commons.collections4.bag.AbstractBagDecorator
equals, getCount, hashCode, remove, uniqueSet
-
Methods inherited from class org.apache.commons.collections4.collection.AbstractCollectionDecorator
clear, contains, isEmpty, iterator, removeIf, size, toArray, toArray, toString
-
-
-
-
Method Detail
-
collectionBag
public static <E> Bag<E> collectionBag(Bag<E> bag)
Factory method to create a bag that complies to the Collection contract.- Type Parameters:
E
- the type of the elements in the bag- Parameters:
bag
- the bag to decorate, must not be null- Returns:
- a Bag that complies to the Collection contract
- Throws:
java.lang.NullPointerException
- if bag is null
-
containsAll
public boolean containsAll(java.util.Collection<?> coll)
(Change) Returnstrue
if the bag contains all elements in the given collection, not respecting cardinality. That is, if the given collectioncoll
contains at least one of every object contained in this object.- Specified by:
containsAll
in interfaceBag<E>
- Specified by:
containsAll
in interfacejava.util.Collection<E>
- Overrides:
containsAll
in classAbstractCollectionDecorator<E>
- Parameters:
coll
- the collection to check against- Returns:
true
if the Bag contains at least one of every object in the collection
-
add
public boolean add(E object)
(Change) Adds one copy of the specified object to the Bag.Since this method always increases the size of the bag, it will always return
true
.
-
addAll
public boolean addAll(java.util.Collection<? extends E> coll)
- Specified by:
addAll
in interfacejava.util.Collection<E>
- Overrides:
addAll
in classAbstractCollectionDecorator<E>
-
remove
public boolean remove(java.lang.Object object)
(Change) Removes the first occurrence of the given object from the bag.This will also remove the object from the
AbstractBagDecorator.uniqueSet()
if the bag contains no occurrence anymore of the object after this operation.
-
removeAll
public boolean removeAll(java.util.Collection<?> coll)
(Change) Remove all elements represented in the given collection, not respecting cardinality. That is, remove all occurrences of every object contained in the given collection.
-
retainAll
public boolean retainAll(java.util.Collection<?> coll)
(Change) Remove any members of the bag that are not in the given collection, not respecting cardinality. That is, any object in the given collectioncoll
will be retained in the bag with the same number of copies prior to this operation. All other objects will be completely removed from this bag.This implementation iterates over the elements of this bag, checking each element in turn to see if it's contained in
coll
. If it's not contained, it's removed from this bag. As a consequence, it is advised to use a collection type forcoll
that provides a fast (e.g. O(1)) implementation ofCollection.contains(Object)
.
-
add
public boolean add(E object, int count)
(Change) Addscount
copies of the specified object to the Bag.Since this method always increases the size of the bag, it will always return
true
.
-
-