Class SpscArrayQueue<E>
- Type Parameters:
E- the element type of the queue
- All Implemented Interfaces:
SimplePlainQueue<E>, SimpleQueue<E>, Serializable
This implementation is a mashup of the Fast Flow
algorithm with an optimization of the offer method taken from the BQueue algorithm (a variation on Fast
Flow), and adjusted to comply with Queue.offer semantics with regards to capacity.
For convenience the relevant papers are available in the resources folder:
2010 - Pisa - SPSC Queues on Shared Cache Multi-Core Systems.pdf
2012 - Junchang- BQueue- Efficient and Practical Queuing.pdf
This implementation is wait free.
- Since:
- 3.1.1
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) final AtomicLong(package private) final int(package private) final intprivate static final Integer(package private) final AtomicLong(package private) longprivate static final long -
Constructor Summary
ConstructorsConstructorDescriptionSpscArrayQueue(int capacity) Constructs an array-backed queue with the given capacity rounded up to the next power of 2 size. -
Method Summary
Modifier and TypeMethodDescription(package private) intcalcElementOffset(long index) (package private) intcalcElementOffset(long index, int mask) voidclear()Removes all enqueued items from this queue.booleanisEmpty()Returns true if the queue is empty.(package private) ElvElement(int offset) booleanAtomically enqueue a single value.booleanAtomically enqueue two values.poll()Tries to dequeue a value (non-null) or returns null if the queue is empty.(package private) voidsoConsumerIndex(long newIndex) (package private) void(package private) voidsoProducerIndex(long newIndex) Methods inherited from class AtomicReferenceArray
accumulateAndGet, compareAndExchange, compareAndExchangeAcquire, compareAndExchangeRelease, compareAndSet, get, getAcquire, getAndAccumulate, getAndSet, getAndUpdate, getOpaque, getPlain, lazySet, length, set, setOpaque, setPlain, setRelease, toString, updateAndGet, weakCompareAndSet, weakCompareAndSetAcquire, weakCompareAndSetPlain, weakCompareAndSetRelease, weakCompareAndSetVolatile
-
Field Details
-
serialVersionUID
private static final long serialVersionUID- See Also:
-
MAX_LOOK_AHEAD_STEP
-
mask
final int mask -
producerIndex
-
producerLookAhead
long producerLookAhead -
consumerIndex
-
lookAheadStep
final int lookAheadStep
-
-
Constructor Details
-
SpscArrayQueue
public SpscArrayQueue(int capacity) Constructs an array-backed queue with the given capacity rounded up to the next power of 2 size.- Parameters:
capacity- the maximum number of elements the queue would hold, rounded up to the next power of 2
-
-
Method Details
-
offer
Description copied from interface:SimpleQueueAtomically enqueue a single value.- Specified by:
offerin interfaceSimpleQueue<E>- Parameters:
e- the value to enqueue, not null- Returns:
- true if successful, false if the value was not enqueued likely due to reaching the queue capacity)
-
offer
Description copied from interface:SimpleQueueAtomically enqueue two values.- Specified by:
offerin interfaceSimpleQueue<E>- Parameters:
v1- the first value to enqueue, not nullv2- the second value to enqueue, not null- Returns:
- true if successful, false if the value was not enqueued likely due to reaching the queue capacity)
-
poll
Description copied from interface:SimpleQueueTries to dequeue a value (non-null) or returns null if the queue is empty.If the producer uses
SimpleQueue.offer(Object, Object)and when polling in pairs, if the first poll() returns a non-null item, the second poll() is guaranteed to return a non-null item as well.- Specified by:
pollin interfaceSimplePlainQueue<E>- Specified by:
pollin interfaceSimpleQueue<E>- Returns:
- the item or null to indicate an empty queue
-
isEmpty
public boolean isEmpty()Description copied from interface:SimpleQueueReturns true if the queue is empty.Note however that due to potential fused functions in
SimpleQueue.poll()it is possible this method returns false but then poll() returns null because the fused function swallowed the available item(s).- Specified by:
isEmptyin interfaceSimpleQueue<E>- Returns:
- true if the queue is empty
-
soProducerIndex
void soProducerIndex(long newIndex) -
soConsumerIndex
void soConsumerIndex(long newIndex) -
clear
public void clear()Description copied from interface:SimpleQueueRemoves all enqueued items from this queue.- Specified by:
clearin interfaceSimpleQueue<E>
-
calcElementOffset
int calcElementOffset(long index, int mask) -
calcElementOffset
int calcElementOffset(long index) -
soElement
-
lvElement
-