Class SpscUnboundedUnpaddedArrayQueue<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractQueue<E>
org.jctools.queues.unpadded.BaseSpscLinkedUnpaddedArrayQueuePrePad<E>
org.jctools.queues.unpadded.BaseSpscLinkedUnpaddedArrayQueueConsumerColdFields<E>
org.jctools.queues.unpadded.BaseSpscLinkedUnpaddedArrayQueueConsumerField<E>
org.jctools.queues.unpadded.BaseSpscLinkedUnpaddedArrayQueueL2Pad<E>
org.jctools.queues.unpadded.BaseSpscLinkedUnpaddedArrayQueueProducerFields<E>
org.jctools.queues.unpadded.BaseSpscLinkedUnpaddedArrayQueueProducerColdFields<E>
org.jctools.queues.unpadded.BaseSpscLinkedUnpaddedArrayQueue<E>
org.jctools.queues.unpadded.SpscUnboundedUnpaddedArrayQueue<E>
- Type Parameters:
E-
- All Implemented Interfaces:
Iterable<E>, Collection<E>, Queue<E>, IndexedQueueSizeUtil.IndexedQueue, MessagePassingQueue<E>, QueueProgressIndicators
NOTE: This class was automatically generated by org.jctools.queues.unpadded.JavaParsingUnpaddedQueueGenerator
which can found in the jctools-build module. The original source file is SpscUnboundedArrayQueue.java.
An SPSC array queue which starts at initialCapacity and grows indefinitely in linked chunks of the initial size.
The queue grows only when the current chunk is full and elements are not copied on
resize, instead a link to the new chunk is stored in the old chunk for the consumer to follow.
-
Nested Class Summary
Nested classes/interfaces inherited from interface MessagePassingQueue
MessagePassingQueue.Consumer<T>, MessagePassingQueue.ExitCondition, MessagePassingQueue.Supplier<T>, MessagePassingQueue.WaitStrategy -
Field Summary
Fields inherited from class BaseSpscLinkedUnpaddedArrayQueueProducerColdFields
producerBuffer, producerBufferLimit, producerMaskFields inherited from class BaseSpscLinkedUnpaddedArrayQueueConsumerColdFields
consumerBuffer, consumerMaskFields inherited from interface MessagePassingQueue
UNBOUNDED_CAPACITY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionintcapacity()intStuff the queue with elements from the supplier.(package private) final booleanofferColdPath(E[] buffer, long mask, long pIndex, long offset, E v, MessagePassingQueue.Supplier<? extends E> s) Methods inherited from class BaseSpscLinkedUnpaddedArrayQueue
currentConsumerIndex, currentProducerIndex, drain, drain, drain, fill, fill, isEmpty, iterator, linkOldToNew, lvNextArrayAndUnlink, offer, peek, poll, relaxedOffer, relaxedPeek, relaxedPoll, size, soNext, toString, writeToQueueMethods inherited from class BaseSpscLinkedUnpaddedArrayQueueProducerFields
lpProducerIndex, lvProducerIndex, soProducerIndexMethods inherited from class BaseSpscLinkedUnpaddedArrayQueueConsumerField
lpConsumerIndex, lvConsumerIndex, soConsumerIndexMethods inherited from class AbstractCollection
contains, containsAll, remove, removeAll, retainAll, toArray, toArrayMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface Collection
contains, containsAll, equals, hashCode, parallelStream, remove, removeAll, removeIf, retainAll, spliterator, stream, toArray, toArray, toArrayMethods inherited from interface MessagePassingQueue
clear
-
Constructor Details
-
SpscUnboundedUnpaddedArrayQueue
public SpscUnboundedUnpaddedArrayQueue(int chunkSize)
-
-
Method Details
-
offerColdPath
final boolean offerColdPath(E[] buffer, long mask, long pIndex, long offset, E v, MessagePassingQueue.Supplier<? extends E> s) - Specified by:
offerColdPathin classBaseSpscLinkedUnpaddedArrayQueue<E>
-
fill
Description copied from interface:MessagePassingQueueStuff the queue with elements from the supplier. Semantically similar to:while(relaxedOffer(s.get());
There's no strong commitment to the queue being full at the end of a fill. Called from a producer thread subject to the restrictions appropriate to the implementation.Unbounded queues will fill up the queue with a fixed amount rather than fill up to oblivion. WARNING: Explicit assumptions are made with regards to
MessagePassingQueue.Supplier.get()make sure you have read and understood these before using this method.- Specified by:
fillin interfaceMessagePassingQueue<E>- Overrides:
fillin classBaseSpscLinkedUnpaddedArrayQueue<E>- Returns:
- the number of offered elements
-
capacity
public int capacity()- Returns:
- the capacity of this queue or
MessagePassingQueue.UNBOUNDED_CAPACITYif not bounded
-