Package org.jctools.queues
Class SpscGrowableArrayQueue<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractQueue<E>
org.jctools.queues.BaseSpscLinkedArrayQueuePrePad<E>
org.jctools.queues.BaseSpscLinkedArrayQueueConsumerColdFields<E>
org.jctools.queues.BaseSpscLinkedArrayQueueConsumerField<E>
org.jctools.queues.BaseSpscLinkedArrayQueueL2Pad<E>
org.jctools.queues.BaseSpscLinkedArrayQueueProducerFields<E>
org.jctools.queues.BaseSpscLinkedArrayQueueProducerColdFields<E>
org.jctools.queues.BaseSpscLinkedArrayQueue<E>
org.jctools.queues.SpscGrowableArrayQueue<E>
- Type Parameters:
E-
- All Implemented Interfaces:
Iterable<E>,Collection<E>,Queue<E>,IndexedQueueSizeUtil.IndexedQueue,MessagePassingQueue<E>,QueueProgressIndicators
An SPSC array queue which starts at initialCapacity and grows to maxCapacity in linked chunks,
doubling theirs size every time until the full blown backing array is used.
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
FieldsFields inherited from class org.jctools.queues.BaseSpscLinkedArrayQueueProducerColdFields
producerBuffer, producerBufferLimit, producerMaskFields inherited from class org.jctools.queues.BaseSpscLinkedArrayQueueL2Pad
b000, b001, b002, b003, b004, b005, b006, b007, b010, b011, b012, b013, b014, b015, b016, b017, b020, b021, b022, b023, b024, b025, b026, b027, b030, b031, b032, b033, b034, b035, b036, b037, b040, b041, b042, b043, b044, b045, b046, b047, b050, b051, b052, b053, b054, b055, b056, b057, b060, b061, b062, b063, b064, b065, b066, b067, b070, b071, b072, b073, b074, b075, b076, b077, b100, b101, b102, b103, b104, b105, b106, b107, b110, b111, b112, b113, b114, b115, b116, b117, b120, b121, b122, b123, b124, b125, b126, b127, b130, b131, b132, b133, b134, b135, b136, b137, b140, b141, b142, b143, b144, b145, b146, b147, b150, b151, b152, b153, b154, b155, b156, b157, b160, b161, b162, b163, b164, b165, b166, b167, b170, b171, b172, b173, b174, b175, b176, b177Fields inherited from class org.jctools.queues.BaseSpscLinkedArrayQueueConsumerColdFields
consumerBuffer, consumerMaskFields inherited from interface org.jctools.queues.MessagePassingQueue
UNBOUNDED_CAPACITY -
Constructor Summary
ConstructorsConstructorDescriptionSpscGrowableArrayQueue(int capacity) SpscGrowableArrayQueue(int chunkSize, int capacity) -
Method Summary
Modifier and TypeMethodDescriptionprivate voidadjustLookAheadStep(int capacity) intcapacity()(package private) final booleanofferColdPath(E[] buffer, long mask, long index, long offset, E v, MessagePassingQueue.Supplier<? extends E> s) Methods inherited from class org.jctools.queues.BaseSpscLinkedArrayQueue
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 org.jctools.queues.BaseSpscLinkedArrayQueueProducerFields
lpProducerIndex, lvProducerIndex, soProducerIndexMethods inherited from class org.jctools.queues.BaseSpscLinkedArrayQueueConsumerField
lpConsumerIndex, lvConsumerIndex, soConsumerIndexMethods 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
-
Field Details
-
maxQueueCapacity
private final int maxQueueCapacity -
lookAheadStep
private long lookAheadStep
-
-
Constructor Details
-
SpscGrowableArrayQueue
public SpscGrowableArrayQueue(int capacity) -
SpscGrowableArrayQueue
public SpscGrowableArrayQueue(int chunkSize, int capacity)
-
-
Method Details
-
offerColdPath
final boolean offerColdPath(E[] buffer, long mask, long index, long offset, E v, MessagePassingQueue.Supplier<? extends E> s) - Specified by:
offerColdPathin classBaseSpscLinkedArrayQueue<E>
-
adjustLookAheadStep
private void adjustLookAheadStep(int capacity) -
capacity
public int capacity()- Returns:
- the capacity of this queue or
MessagePassingQueue.UNBOUNDED_CAPACITYif not bounded
-