Class SpscLinkedArrayQueue<E>
- java.lang.Object
-
- java.util.AbstractCollection<E>
-
- java.util.AbstractQueue<E>
-
- org.jboss.resteasy.microprofile.client.publisher.SpscLinkedArrayQueue<E>
-
- Type Parameters:
E
- the element type of the queue
- All Implemented Interfaces:
Iterable<E>
,Collection<E>
,Queue<E>
public final class SpscLinkedArrayQueue<E> extends AbstractQueue<E> implements Queue<E>
A single-producer single-consumer array-backed queue which can allocate new arrays in case the consumer is slower than the producer.Code inspired from https://github.com/JCTools/JCTools/blob/master/jctools-core/src/main/java/org/jctools/queues/atomic.
-
-
Constructor Summary
Constructors Constructor Description SpscLinkedArrayQueue(int bufferSize)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description void
clear()
boolean
isEmpty()
Iterator<E>
iterator()
boolean
offer(E e)
boolean
offer(E first, E second)
Offer two elements at the same time.E
peek()
E
poll()
static int
roundToPowerOfTwo(int value)
Find the next larger positive power of two value up from the given value.int
size()
-
Methods inherited from class java.util.AbstractQueue
add, addAll, element, remove
-
Methods inherited from class java.util.AbstractCollection
contains, containsAll, remove, removeAll, retainAll, toArray, toArray, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Collection
addAll, contains, containsAll, equals, hashCode, parallelStream, remove, removeAll, removeIf, retainAll, spliterator, stream, toArray, toArray
-
-
-
-
Method Detail
-
roundToPowerOfTwo
public static int roundToPowerOfTwo(int value)
Find the next larger positive power of two value up from the given value. If value is a power of two then this value will be returned.- Parameters:
value
- from which next positive power of two will be found.- Returns:
- the next positive power of 2 or this value if it is a power of 2.
-
offer
public boolean offer(E e)
This implementation is correct for single producer thread use only.
-
poll
public E poll()
This implementation is correct for single consumer thread use only.
-
clear
public void clear()
- Specified by:
clear
in interfaceCollection<E>
- Overrides:
clear
in classAbstractQueue<E>
-
iterator
public Iterator<E> iterator()
- Specified by:
iterator
in interfaceCollection<E>
- Specified by:
iterator
in interfaceIterable<E>
- Specified by:
iterator
in classAbstractCollection<E>
-
size
public int size()
- Specified by:
size
in interfaceCollection<E>
- Specified by:
size
in classAbstractCollection<E>
-
isEmpty
public boolean isEmpty()
- Specified by:
isEmpty
in interfaceCollection<E>
- Overrides:
isEmpty
in classAbstractCollection<E>
-
-