|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object com.google.common.collect.ForwardingObject com.google.common.collect.ForwardingCollection<E> com.google.common.collect.ForwardingQueue<E>
@GwtCompatible public abstract class ForwardingQueue<E>
A queue which forwards all its method calls to another queue. Subclasses should override one or more methods to modify the behavior of the backing queue as desired per the decorator pattern.
Warning: The methods of ForwardingQueue
forward
indiscriminately to the methods of the delegate. For example,
overriding ForwardingCollection.add(E)
alone will not change the behavior of offer(E)
which can lead to unexpected behavior. In this case, you should
override offer
as well, either providing your own implementation, or
delegating to the provided standardOffer
method.
The standard
methods are not guaranteed to be thread-safe, even
when all of the methods that they depend on are thread-safe.
Constructor Summary | |
---|---|
protected |
ForwardingQueue()
Constructor for use by subclasses. |
Method Summary | |
---|---|
protected abstract Queue<E> |
delegate()
Returns the backing delegate instance that methods are forwarded to. |
E |
element()
Retrieves, but does not remove, the head of this queue. |
boolean |
offer(E o)
Inserts the specified element into this queue if it is possible to do so immediately without violating capacity restrictions. |
E |
peek()
Retrieves, but does not remove, the head of this queue, or returns null if this queue is empty. |
E |
poll()
Retrieves and removes the head of this queue, or returns null if this queue is empty. |
E |
remove()
Retrieves and removes the head of this queue. |
protected boolean |
standardOffer(E e)
A sensible definition of offer(E) in terms of ForwardingCollection.add(E) . |
protected E |
standardPeek()
A sensible definition of peek() in terms of element() . |
protected E |
standardPoll()
A sensible definition of poll() in terms of remove() . |
Methods inherited from class com.google.common.collect.ForwardingCollection |
---|
add, addAll, clear, contains, containsAll, isEmpty, iterator, remove, removeAll, retainAll, size, standardAddAll, standardClear, standardContains, standardContainsAll, standardIsEmpty, standardRemove, standardRemoveAll, standardRetainAll, standardToArray, standardToArray, standardToString, toArray, toArray |
Methods inherited from class com.google.common.collect.ForwardingObject |
---|
toString |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Methods inherited from interface java.util.Queue |
---|
add |
Methods inherited from interface java.util.Collection |
---|
addAll, clear, contains, containsAll, equals, hashCode, isEmpty, iterator, remove, removeAll, retainAll, size, toArray, toArray |
Constructor Detail |
---|
protected ForwardingQueue()
Method Detail |
---|
protected abstract Queue<E> delegate()
ForwardingObject
ForwardingSet.delegate()
. Concrete subclasses override this method to supply
the instance being decorated.
delegate
in class ForwardingCollection<E>
public boolean offer(E o)
java.util.Queue
Queue.add(E)
, which can fail to insert an element only
by throwing an exception.
offer
in interface Queue<E>
o
- the element to add
public E poll()
java.util.Queue
poll
in interface Queue<E>
public E remove()
java.util.Queue
poll
only in that it throws an exception if this
queue is empty.
remove
in interface Queue<E>
public E peek()
java.util.Queue
peek
in interface Queue<E>
public E element()
java.util.Queue
peek
only in that it throws an exception
if this queue is empty.
element
in interface Queue<E>
@Beta protected boolean standardOffer(E e)
offer(E)
in terms of ForwardingCollection.add(E)
. If you
override ForwardingCollection.add(E)
, you may wish to override offer(E)
to forward
to this implementation.
@Beta protected E standardPeek()
peek()
in terms of element()
. If you
override element()
, you may wish to override peek()
to
forward to this implementation.
@Beta protected E standardPoll()
poll()
in terms of remove()
. If you
override remove()
, you may wish to override poll()
to forward
to this implementation.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |