Package org.elasticsearch.common.collect
Class EvictingQueue<T>
java.lang.Object
org.elasticsearch.common.collect.EvictingQueue<T>
- Type Parameters:
T
- The type of elements in the queue.
- All Implemented Interfaces:
Iterable<T>
,Collection<T>
,Queue<T>
An
EvictingQueue
is a non-blocking queue which is limited to a maximum size; when new elements are added to a
full queue, elements are evicted from the head of the queue to accommodate the new elements.-
Constructor Summary
ConstructorDescriptionEvictingQueue(int maximumSize)
Construct a newEvictingQueue
that holdsmaximumSize
elements. -
Method Summary
Modifier and TypeMethodDescriptionboolean
Add the given element to the queue, possibly forcing an eviction from the head ifremainingCapacity()
is zero.boolean
addAll(Collection<? extends T> c)
Add the given elements to the queue, possibly forcing evictions from the head ifremainingCapacity()
is zero or becomes zero during the execution of this method.void
clear()
boolean
boolean
containsAll(Collection<?> c)
element()
boolean
isEmpty()
iterator()
boolean
peek()
poll()
int
remove()
boolean
boolean
removeAll(Collection<?> c)
boolean
retainAll(Collection<?> c)
int
size()
Object[]
toArray()
<T1> T1[]
toArray(T1[] a)
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface java.util.Collection
equals, hashCode, parallelStream, removeIf, spliterator, stream, toArray
-
Constructor Details
-
EvictingQueue
public EvictingQueue(int maximumSize)Construct a newEvictingQueue
that holdsmaximumSize
elements.- Parameters:
maximumSize
- The maximum number of elements that the queue can hold- Throws:
IllegalArgumentException
- ifmaximumSize
is less than zero
-
-
Method Details
-
remainingCapacity
public int remainingCapacity()- Returns:
- the number of additional elements that the queue can accommodate before evictions occur
-
add
Add the given element to the queue, possibly forcing an eviction from the head ifremainingCapacity()
is zero. -
offer
- Specified by:
offer
in interfaceQueue<T>
- See Also:
add(Object)
-
remove
-
poll
-
element
-
peek
-
size
public int size()- Specified by:
size
in interfaceCollection<T>
-
isEmpty
public boolean isEmpty()- Specified by:
isEmpty
in interfaceCollection<T>
-
contains
- Specified by:
contains
in interfaceCollection<T>
-
iterator
-
toArray
- Specified by:
toArray
in interfaceCollection<T>
-
toArray
public <T1> T1[] toArray(T1[] a)- Specified by:
toArray
in interfaceCollection<T>
-
remove
- Specified by:
remove
in interfaceCollection<T>
-
containsAll
- Specified by:
containsAll
in interfaceCollection<T>
-
addAll
Add the given elements to the queue, possibly forcing evictions from the head ifremainingCapacity()
is zero or becomes zero during the execution of this method.- Specified by:
addAll
in interfaceCollection<T>
- Parameters:
c
- the collection of elements to add- Returns:
- true if any elements were added to the queue
-
removeAll
- Specified by:
removeAll
in interfaceCollection<T>
-
retainAll
- Specified by:
retainAll
in interfaceCollection<T>
-
clear
public void clear()- Specified by:
clear
in interfaceCollection<T>
-