java.lang.Object
com.google.common.collect.ForwardingObject
com.google.common.collect.ForwardingCollection<E>
- All Implemented Interfaces:
- Iterable<E>, Collection<E>
- Direct Known Subclasses:
- ForwardingList, ForwardingMultiset, ForwardingQueue, ForwardingSet
@GwtCompatible
public abstract class ForwardingCollection<E extends @Nullable Object>
extends ForwardingObject
implements Collection<E>
A collection which forwards all its method calls to another collection. Subclasses should
override one or more methods to modify the behavior of the backing collection as desired per the
decorator pattern.
Warning: The methods of ForwardingCollection forward indiscriminately to
the methods of the delegate. For example, overriding add(E) alone will not change
the behavior of addAll(Collection), which can lead to unexpected behavior. In this case, you should
override addAll as well, either providing your own implementation, or delegating to the
provided standardAddAll method.
default method warning: This class does not forward calls to 
default methods. Instead, it inherits their default implementations. When those implementations
invoke methods, they invoke methods on the ForwardingCollection.
The standard methods are not guaranteed to be thread-safe, even when all of the
methods that they depend on are thread-safe.
- Since:
- 2.0
- Author:
- Kevin Bourrillion, Louis Wasserman
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedConstructor for use by subclasses.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanbooleanaddAll(Collection<? extends E> collection) voidclear()booleanbooleancontainsAll(Collection<?> collection) protected abstract Collection<E> delegate()Returns the backing delegate instance that methods are forwarded to.booleanisEmpty()iterator()booleanbooleanremoveAll(Collection<?> collection) booleanretainAll(Collection<?> collection) intsize()protected booleanstandardAddAll(Collection<? extends E> collection) A sensible definition ofaddAll(Collection)in terms ofadd(E).protected voidprotected booleanstandardContains(@Nullable Object object) A sensible definition ofcontains(Object)in terms ofiterator().protected booleanstandardContainsAll(Collection<?> collection) A sensible definition ofcontainsAll(Collection)in terms ofcontains(Object).protected booleanA sensible definition ofisEmpty()as!iterator().hasNext.protected booleanstandardRemove(@Nullable Object object) protected booleanstandardRemoveAll(Collection<?> collection) A sensible definition ofremoveAll(Collection)in terms ofiterator(), using the iterator'sremovemethod.protected booleanstandardRetainAll(Collection<?> collection) A sensible definition ofretainAll(Collection)in terms ofiterator(), using the iterator'sremovemethod.A sensible definition oftoArray()in terms oftoArray(Object[]).standardToArray(T[] array) protected StringA sensible definition ofForwardingObject.toString()in terms ofiterator().toArray()toArray(T[] array) Methods inherited from class ForwardingObjecttoStringMethods inherited from class Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface Collectionequals, hashCode, parallelStream, removeIf, spliterator, stream, toArray
- 
Constructor Details- 
ForwardingCollectionprotected ForwardingCollection()Constructor for use by subclasses.
 
- 
- 
Method Details- 
delegateDescription copied from class:ForwardingObjectReturns the backing delegate instance that methods are forwarded to. Abstract subclasses generally override this method with an abstract method that has a more specific return type, such asForwardingSet.delegate(). Concrete subclasses override this method to supply the instance being decorated.- Specified by:
- delegatein class- ForwardingObject
 
- 
iterator
- 
sizepublic int size()- Specified by:
- sizein interface- Collection<E extends @Nullable Object>
 
- 
removeAll- Specified by:
- removeAllin interface- Collection<E extends @Nullable Object>
 
- 
isEmptypublic boolean isEmpty()- Specified by:
- isEmptyin interface- Collection<E extends @Nullable Object>
 
- 
contains
- 
add- Specified by:
- addin interface- Collection<E extends @Nullable Object>
 
- 
remove- Specified by:
- removein interface- Collection<E extends @Nullable Object>
 
- 
containsAll- Specified by:
- containsAllin interface- Collection<E extends @Nullable Object>
 
- 
addAll- Specified by:
- addAllin interface- Collection<E extends @Nullable Object>
 
- 
retainAll- Specified by:
- retainAllin interface- Collection<E extends @Nullable Object>
 
- 
clearpublic void clear()- Specified by:
- clearin interface- Collection<E extends @Nullable Object>
 
- 
toArray
- 
toArray- Specified by:
- toArrayin interface- Collection<E extends @Nullable Object>
 
- 
standardContainsA sensible definition ofcontains(Object)in terms ofiterator(). If you overrideiterator(), you may wish to overridecontains(Object)to forward to this implementation.- Since:
- 7.0
 
- 
standardContainsAllA sensible definition ofcontainsAll(Collection)in terms ofcontains(Object). If you overridecontains(Object), you may wish to overridecontainsAll(Collection)to forward to this implementation.- Since:
- 7.0
 
- 
standardAddAllA sensible definition ofaddAll(Collection)in terms ofadd(E). If you overrideadd(E), you may wish to overrideaddAll(Collection)to forward to this implementation.- Since:
- 7.0
 
- 
standardRemoveA sensible definition ofremove(Object)in terms ofiterator(), using the iterator'sremovemethod. If you overrideiterator(), you may wish to overrideremove(Object)to forward to this implementation.- Since:
- 7.0
 
- 
standardRemoveAllA sensible definition ofremoveAll(Collection)in terms ofiterator(), using the iterator'sremovemethod. If you overrideiterator(), you may wish to overrideremoveAll(Collection)to forward to this implementation.- Since:
- 7.0
 
- 
standardRetainAllA sensible definition ofretainAll(Collection)in terms ofiterator(), using the iterator'sremovemethod. If you overrideiterator(), you may wish to overrideretainAll(Collection)to forward to this implementation.- Since:
- 7.0
 
- 
standardClearprotected void standardClear()A sensible definition ofclear()in terms ofiterator(), using the iterator'sremovemethod. If you overrideiterator(), you may wish to overrideclear()to forward to this implementation.- Since:
- 7.0
 
- 
standardIsEmpty
- 
standardToStringA sensible definition ofForwardingObject.toString()in terms ofiterator(). If you overrideiterator(), you may wish to overrideForwardingObject.toString()to forward to this implementation.- Since:
- 7.0
 
- 
standardToArrayA sensible definition oftoArray()in terms oftoArray(Object[]). If you overridetoArray(Object[]), you may wish to overridetoArray()to forward to this implementation.- Since:
- 7.0
 
- 
standardToArrayA sensible definition oftoArray(Object[])in terms ofsize()anditerator(). If you override either of these methods, you may wish to overridetoArray()to forward to this implementation.- Since:
- 7.0
 
 
-