Class SpscChunkedAtomicUnpaddedArrayQueue<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractQueue<E>
org.jctools.queues.atomic.unpadded.BaseSpscLinkedAtomicUnpaddedArrayQueuePrePad<E>
org.jctools.queues.atomic.unpadded.BaseSpscLinkedAtomicUnpaddedArrayQueueConsumerColdFields<E>
org.jctools.queues.atomic.unpadded.BaseSpscLinkedAtomicUnpaddedArrayQueueConsumerField<E>
org.jctools.queues.atomic.unpadded.BaseSpscLinkedAtomicUnpaddedArrayQueueL2Pad<E>
org.jctools.queues.atomic.unpadded.BaseSpscLinkedAtomicUnpaddedArrayQueueProducerFields<E>
org.jctools.queues.atomic.unpadded.BaseSpscLinkedAtomicUnpaddedArrayQueueProducerColdFields<E>
org.jctools.queues.atomic.unpadded.BaseSpscLinkedAtomicUnpaddedArrayQueue<E>
org.jctools.queues.atomic.unpadded.SpscChunkedAtomicUnpaddedArrayQueue<E>
- Type Parameters:
E-
- All Implemented Interfaces:
Iterable<E>, Collection<E>, Queue<E>, IndexedQueueSizeUtil.IndexedQueue, MessagePassingQueue<E>, QueueProgressIndicators
public class SpscChunkedAtomicUnpaddedArrayQueue<E>
extends BaseSpscLinkedAtomicUnpaddedArrayQueue<E>
NOTE: This class was automatically generated by org.jctools.queues.atomic.unpadded.JavaParsingAtomicUnpaddedLinkedQueueGenerator
which can found in the jctools-build module. The original source file is SpscChunkedArrayQueue.java.
An SPSC array queue which starts at initialCapacity and grows to maxCapacity 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
FieldsModifier and TypeFieldDescriptionprivate final intprivate longFields inherited from class BaseSpscLinkedAtomicUnpaddedArrayQueueProducerColdFields
producerBuffer, producerBufferLimit, producerMaskFields inherited from class BaseSpscLinkedAtomicUnpaddedArrayQueueConsumerColdFields
consumerBuffer, consumerMaskFields inherited from interface MessagePassingQueue
UNBOUNDED_CAPACITY -
Constructor Summary
ConstructorsConstructorDescriptionSpscChunkedAtomicUnpaddedArrayQueue(int capacity) SpscChunkedAtomicUnpaddedArrayQueue(int chunkSize, int capacity) -
Method Summary
Modifier and TypeMethodDescriptionintcapacity()(package private) final booleanofferColdPath(AtomicReferenceArray<E> buffer, long mask, long pIndex, int offset, E v, MessagePassingQueue.Supplier<? extends E> s) Methods inherited from class BaseSpscLinkedAtomicUnpaddedArrayQueue
currentConsumerIndex, currentProducerIndex, drain, drain, drain, fill, fill, fill, isEmpty, iterator, linkOldToNew, lvNextArrayAndUnlink, offer, peek, poll, relaxedOffer, relaxedPeek, relaxedPoll, size, soNext, toString, writeToQueueMethods inherited from class BaseSpscLinkedAtomicUnpaddedArrayQueueProducerFields
lpProducerIndex, lvProducerIndex, soProducerIndexMethods inherited from class BaseSpscLinkedAtomicUnpaddedArrayQueueConsumerField
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
-
Field Details
-
maxQueueCapacity
private final int maxQueueCapacity -
producerQueueLimit
private long producerQueueLimit
-
-
Constructor Details
-
SpscChunkedAtomicUnpaddedArrayQueue
public SpscChunkedAtomicUnpaddedArrayQueue(int capacity) -
SpscChunkedAtomicUnpaddedArrayQueue
public SpscChunkedAtomicUnpaddedArrayQueue(int chunkSize, int capacity)
-
-
Method Details
-
offerColdPath
final boolean offerColdPath(AtomicReferenceArray<E> buffer, long mask, long pIndex, int offset, E v, MessagePassingQueue.Supplier<? extends E> s) - Specified by:
offerColdPathin classBaseSpscLinkedAtomicUnpaddedArrayQueue<E>
-
capacity
public int capacity()- Returns:
- the capacity of this queue or
MessagePassingQueue.UNBOUNDED_CAPACITYif not bounded
-