Class MpscUnboundedVarHandleUnpaddedArrayQueue<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.MpscUnboundedVarHandleUnpaddedArrayQueue<E>
- All Implemented Interfaces:
Iterable<E>,Collection<E>,Queue<E>,IndexedQueueSizeUtil.IndexedQueue,MessagePassingQueue<E>,QueueProgressIndicators
public class MpscUnboundedVarHandleUnpaddedArrayQueue<E>
extends BaseMpscLinkedVarHandleUnpaddedArrayQueue<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 MpscUnboundedArrayQueue.java.
An MPSC 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 org.jctools.queues.MessagePassingQueue
MessagePassingQueue.Consumer<T>, MessagePassingQueue.ExitCondition, MessagePassingQueue.Supplier<T>, MessagePassingQueue.WaitStrategy -
Field Summary
Fields inherited from class org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueColdProducerFields
producerBuffer, producerMaskFields inherited from class org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueConsumerFields
consumerBuffer, consumerMaskFields inherited from interface org.jctools.queues.MessagePassingQueue
UNBOUNDED_CAPACITY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected longavailableInQueue(long pIndex, long cIndex) intcapacity()intRemove all available item from the queue and hand to consume.intStuff the queue with elements from the supplier.protected longgetCurrentBufferCapacity(long mask) protected intgetNextBufferSize(E[] buffer) Methods inherited from class org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueue
currentConsumerIndex, currentProducerIndex, drain, drain, fill, fill, isEmpty, iterator, offer, peek, poll, relaxedOffer, relaxedPeek, relaxedPoll, size, toStringMethods inherited from class org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueColdProducerFields
casProducerLimit, lvProducerLimit, soProducerLimitMethods inherited from class org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueConsumerFields
lpConsumerIndex, lvConsumerIndex, soConsumerIndexMethods inherited from class org.jctools.queues.varhandle.unpadded.BaseMpscLinkedVarHandleUnpaddedArrayQueueProducerFields
casProducerIndex, lvProducerIndex, soProducerIndexMethods inherited from class java.util.AbstractCollection
contains, containsAll, remove, removeAll, retainAll, toArray, toArrayMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface java.util.Collection
contains, containsAll, equals, hashCode, parallelStream, remove, removeAll, removeIf, retainAll, spliterator, stream, toArray, toArray, toArrayMethods inherited from interface org.jctools.queues.MessagePassingQueue
clear
-
Constructor Details
-
MpscUnboundedVarHandleUnpaddedArrayQueue
public MpscUnboundedVarHandleUnpaddedArrayQueue(int chunkSize)
-
-
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
-
drain
Description copied from interface:MessagePassingQueueRemove all available item from the queue and hand to consume. This should be semantically similar to:M m; while((m = relaxedPoll()) != null){ c.accept(m); }There's no strong commitment to the queue being empty at the end of a drain. Called from a consumer thread subject to the restrictions appropriate to the implementation.WARNING: Explicit assumptions are made with regards to
MessagePassingQueue.Consumer.accept(T)make sure you have read and understood these before using this method.- Specified by:
drainin interfaceMessagePassingQueue<E>- Overrides:
drainin classBaseMpscLinkedVarHandleUnpaddedArrayQueue<E>- Returns:
- the number of polled elements
-
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 classBaseMpscLinkedVarHandleUnpaddedArrayQueue<E>- Returns:
- the number of offered elements
-
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
-