Class MpscChunkedVarHandleUnpaddedArrayQueue<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractQueue<E>
org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueuePad1<E>
org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueProducerFields<E>
org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueuePad2<E>
org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueConsumerFields<E>
org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueuePad3<E>
org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueColdProducerFields<E>
org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueue<E>
org.jctools.queues.varhandle.unpadded.MpscChunkedVarHandleUnpaddedArrayQueueColdProducerFields<E>
org.jctools.queues.varhandle.unpadded.MpscChunkedVarHandleUnpaddedArrayQueue<E>
- All Implemented Interfaces:
Iterable<E>, Collection<E>, Queue<E>, IndexedQueueSizeUtil.IndexedQueue, MessagePassingQueue<E>, QueueProgressIndicators
- Direct Known Subclasses:
MpscGrowableVarHandleUnpaddedArrayQueue
public class MpscChunkedVarHandleUnpaddedArrayQueue<E>
extends MpscChunkedVarHandleUnpaddedArrayQueueColdProducerFields<E>
NOTE: This class was automatically generated by org.jctools.queues.varhandle.unpadded.JavaParsingVarHandleUnpaddedLinkedQueueGenerator
which can found in the jctools-build module. The original source file is MpscChunkedArrayQueue.java.
An MPSC 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
Fields inherited from class MpscChunkedVarHandleUnpaddedArrayQueueColdProducerFields
maxQueueCapacityFields inherited from class BaseMpscLinkedVarHandleUnpaddedArrayQueueColdProducerFields
producerBuffer, producerMaskFields inherited from class BaseMpscLinkedVarHandleUnpaddedArrayQueueConsumerFields
consumerBuffer, consumerMaskFields inherited from interface MessagePassingQueue
UNBOUNDED_CAPACITY -
Constructor Summary
ConstructorsConstructorDescriptionMpscChunkedVarHandleUnpaddedArrayQueue(int maxCapacity) MpscChunkedVarHandleUnpaddedArrayQueue(int initialCapacity, int maxCapacity) -
Method Summary
Modifier and TypeMethodDescriptionprotected longavailableInQueue(long pIndex, long cIndex) intcapacity()protected longgetCurrentBufferCapacity(long mask) protected intgetNextBufferSize(E[] buffer) Methods inherited from class BaseMpscLinkedVarHandleUnpaddedArrayQueue
currentConsumerIndex, currentProducerIndex, drain, drain, drain, fill, fill, fill, isEmpty, iterator, offer, peek, poll, relaxedOffer, relaxedPeek, relaxedPoll, size, toStringMethods inherited from class BaseMpscLinkedVarHandleUnpaddedArrayQueueColdProducerFields
casProducerLimit, lvProducerLimit, soProducerLimitMethods inherited from class BaseMpscLinkedVarHandleUnpaddedArrayQueueConsumerFields
lpConsumerIndex, lvConsumerIndex, soConsumerIndexMethods inherited from class BaseMpscLinkedVarHandleUnpaddedArrayQueueProducerFields
casProducerIndex, lvProducerIndex, soProducerIndexMethods 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
-
MpscChunkedVarHandleUnpaddedArrayQueue
public MpscChunkedVarHandleUnpaddedArrayQueue(int maxCapacity) -
MpscChunkedVarHandleUnpaddedArrayQueue
public MpscChunkedVarHandleUnpaddedArrayQueue(int initialCapacity, int maxCapacity) - Parameters:
initialCapacity- the queue initial capacity. If chunk size is fixed this will be the chunk size. Must be 2 or more.maxCapacity- the maximum capacity will be rounded up to the closest power of 2 and will be the upper limit of number of elements in this queue. Must be 4 or more and round up to a larger power of 2 than initialCapacity.
-
-
Method Details
-
availableInQueue
protected long availableInQueue(long pIndex, long cIndex) - Specified by:
availableInQueuein classBaseMpscLinkedVarHandleUnpaddedArrayQueue<E>- Returns:
- available elements in queue * 2
-
capacity
public int capacity()- Specified by:
capacityin interfaceIndexedQueueSizeUtil.IndexedQueue- Specified by:
capacityin interfaceMessagePassingQueue<E>- Specified by:
capacityin classBaseMpscLinkedVarHandleUnpaddedArrayQueue<E>- Returns:
- the capacity of this queue or
MessagePassingQueue.UNBOUNDED_CAPACITYif not bounded
-
getNextBufferSize
- Specified by:
getNextBufferSizein classBaseMpscLinkedVarHandleUnpaddedArrayQueue<E>- Returns:
- next buffer size(inclusive of next array pointer)
-
getCurrentBufferCapacity
protected long getCurrentBufferCapacity(long mask) - Specified by:
getCurrentBufferCapacityin classBaseMpscLinkedVarHandleUnpaddedArrayQueue<E>- Returns:
- current buffer capacity for elements (excluding next pointer and jump entry) * 2
-