Class DoubleBigSpliterators.AbstractIndexBasedSpliterator

  • All Implemented Interfaces:
    DoubleSpliterator, java.util.Spliterator<java.lang.Double>, java.util.Spliterator.OfDouble, java.util.Spliterator.OfPrimitive<java.lang.Double,​java.util.function.DoubleConsumer,​java.util.Spliterator.OfDouble>
    Direct Known Subclasses:
    DoubleBigSpliterators.EarlyBindingSizeIndexBasedSpliterator, DoubleBigSpliterators.LateBindingSizeIndexBasedSpliterator
    Enclosing class:
    DoubleBigSpliterators

    public abstract static class DoubleBigSpliterators.AbstractIndexBasedSpliterator
    extends AbstractDoubleSpliterator
    A skeletal implementation for a spliterator backed by an index based data store. High performance concrete implementations (like the main Spliterator of BigArrayBigList) generally should avoid using this and just implement the interface directly, but should be decent for less performance critical implementations.

    As the abstract methods in this class are used in inner loops, it is generally a good idea to override the class as final as to encourage the JVM to inline them (or alternatively, override the abstract methods as final).

    • Nested Class Summary

      • Nested classes/interfaces inherited from interface java.util.Spliterator

        java.util.Spliterator.OfDouble, java.util.Spliterator.OfInt, java.util.Spliterator.OfLong, java.util.Spliterator.OfPrimitive<T extends java.lang.Object,​T_CONS extends java.lang.Object,​T_SPLITR extends java.util.Spliterator.OfPrimitive<T,​T_CONS,​T_SPLITR>>
    • Field Summary

      • Fields inherited from interface java.util.Spliterator

        CONCURRENT, DISTINCT, IMMUTABLE, NONNULL, ORDERED, SIZED, SORTED, SUBSIZED
    • Method Detail

      • characteristics

        public int characteristics()
      • estimateSize

        public long estimateSize()
      • tryAdvance

        public boolean tryAdvance​(java.util.function.DoubleConsumer action)
      • forEachRemaining

        public void forEachRemaining​(java.util.function.DoubleConsumer action)
      • trySplit

        public DoubleSpliterator trySplit()
        Throws:
        java.lang.IndexOutOfBoundsException - if the return of computeSplitPoint() was < pos or > {@link #getMaxPos()}.
        Implementation Specification:
        This implementation always returns a prefix of the elements, in order to comply with the Spliterator.ORDERED property. This means this current iterator does not need to to update what getMaxPos() returns in response to this method (but it may do "book-keeping" on it based on binding strategy).

        The split point is computed by computeSplitPoint(); see that method for details.