Class DoubleIterators.AbstractIndexBasedListIterator

java.lang.Object
All Implemented Interfaces:
BidirectionalIterator<java.lang.Double>, DoubleBidirectionalIterator, DoubleIterator, DoubleListIterator, ObjectBidirectionalIterator<java.lang.Double>, ObjectIterator<java.lang.Double>, java.util.Iterator<java.lang.Double>, java.util.ListIterator<java.lang.Double>, java.util.PrimitiveIterator<java.lang.Double,​java.util.function.DoubleConsumer>, java.util.PrimitiveIterator.OfDouble
Enclosing class:
DoubleIterators

public abstract static class DoubleIterators.AbstractIndexBasedListIterator
extends DoubleIterators.AbstractIndexBasedIterator
implements DoubleListIterator
A skeletal implementation for a list-iterator backed by an index-based data store. High performance concrete implementations (like the main ListIterator of ArrayList) generally should avoid using this and just implement the interface directly, but should be decent for less performance critical implementations.

This class is only appropriate for sequences that are at most Integer.MAX_VALUE long. If your backing data store can be bigger then this, consider the equivalently named class in the type specific BigListSpliterators class.

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).

  • Method Details

    • hasPrevious

      public boolean hasPrevious()
      Description copied from interface: BidirectionalIterator
      Returns whether there is a previous element.
      Specified by:
      hasPrevious in interface BidirectionalIterator<java.lang.Double>
      Specified by:
      hasPrevious in interface java.util.ListIterator<java.lang.Double>
      Returns:
      whether there is a previous element.
      See Also:
      ListIterator.hasPrevious()
    • previousDouble

      public double previousDouble()
      Description copied from interface: DoubleBidirectionalIterator
      Returns the previous element as a primitive type.
      Specified by:
      previousDouble in interface DoubleBidirectionalIterator
      Returns:
      the previous element in the iteration.
      See Also:
      ListIterator.previous()
    • nextIndex

      public int nextIndex()
      Specified by:
      nextIndex in interface java.util.ListIterator<java.lang.Double>
    • previousIndex

      public int previousIndex()
      Specified by:
      previousIndex in interface java.util.ListIterator<java.lang.Double>
    • add

      public void add​(double k)
      Description copied from interface: DoubleListIterator
      Inserts the specified element into the list (optional operation).

      This default implementation just throws an UnsupportedOperationException.

      Specified by:
      add in interface DoubleListIterator
      Parameters:
      k - the element to insert.
      See Also:
      ListIterator.add(Object)
    • set

      public void set​(double k)
      Description copied from interface: DoubleListIterator
      Replaces the last element returned by DoubleListIterator.next() or DoubleListIterator.previous() with the specified element (optional operation).
      Specified by:
      set in interface DoubleListIterator
      Parameters:
      k - the element used to replace the last element returned.

      This default implementation just throws an UnsupportedOperationException.

      See Also:
      ListIterator.set(Object)
    • back

      public int back​(int n)
      Description copied from interface: DoubleBidirectionalIterator
      Moves back for the given number of elements.

      The effect of this call is exactly the same as that of calling DoubleBidirectionalIterator.previous() for n times (possibly stopping if BidirectionalIterator.hasPrevious() becomes false).

      Specified by:
      back in interface DoubleBidirectionalIterator
      Specified by:
      back in interface ObjectBidirectionalIterator<java.lang.Double>
      Parameters:
      n - the number of elements to skip back.
      Returns:
      the number of elements actually skipped.
      See Also:
      DoubleBidirectionalIterator.previous()