|
Apache Tomcat 7.0.28 | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.jasper.util.FastRemovalDequeue<T>
public class FastRemovalDequeue<T>
The FastRemovalDequeue is a Dequeue that supports constant time removal of entries. This is achieved by using a doubly linked list and wrapping any object added to the collection with an Entry type, that is returned to the consumer. When removing an object from the list, the consumer provides this Entry object. The Entry type is nearly opaque to the consumer of the queue. The only public member is the getter for any object displaced when adding a new object to the queue. This can be used to destroy that object. The Entry object contains the links pointing to the neighbours in the doubly linked list, so that removal of an Entry does not need to search for it but instead can be done in constant time. The implementation is fully thread-safe. Invalidation of Entry objects during removal from the list is done by setting their "valid" field to false. All public methods which take Entry objects as arguments are NOP if the entry is no longer valid. A typical use of the FastRemovalDequeue is a list of entries in sorted order, where the sort position of an object will only switch to first or last. Whenever the sort position needs to change, the consumer can remove the object and reinsert it in front or at the end in constant time. So keeping the list sorted is very cheap.
Nested Class Summary | |
---|---|
class |
FastRemovalDequeue.Entry
Implementation of a doubly linked list entry. |
Field Summary | |
---|---|
protected FastRemovalDequeue.Entry |
first
First element of the queue. |
protected FastRemovalDequeue.Entry |
last
Last element of the queue. |
Constructor Summary | |
---|---|
FastRemovalDequeue(int maxSize)
Initialize empty queue. |
Method Summary | |
---|---|
int |
getSize()
Retrieve the size of the list. |
void |
moveFirst(FastRemovalDequeue.Entry element)
Moves the element in front. |
void |
moveLast(FastRemovalDequeue.Entry element)
Moves the element to the back. |
T |
pop()
Removes the last element of the list and returns its content. |
FastRemovalDequeue.Entry |
push(T object)
Adds an object to the start of the list and returns the entry created for said object. |
void |
remove(FastRemovalDequeue.Entry element)
Removes any element of the list and returns its content. |
FastRemovalDequeue.Entry |
unpop(T object)
Adds an object to the end of the list and returns the entry created for said object. |
T |
unpush()
Removes the first element of the list and returns its content. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected FastRemovalDequeue.Entry first
protected FastRemovalDequeue.Entry last
Constructor Detail |
---|
public FastRemovalDequeue(int maxSize)
Method Detail |
---|
public int getSize()
public FastRemovalDequeue.Entry push(T object)
object
- the object to prepend to the start of the list.
public FastRemovalDequeue.Entry unpop(T object)
object
- the object to append to the end of the list.
public T unpush()
public T pop()
public void remove(FastRemovalDequeue.Entry element)
public void moveFirst(FastRemovalDequeue.Entry element)
element
- the entry to move in front.public void moveLast(FastRemovalDequeue.Entry element)
element
- the entry to move to the back.
|
Apache Tomcat 7.0.28 | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |