Class IntIterators.AbstractIndexBasedIterator

  • All Implemented Interfaces:
    IntIterator, java.util.Iterator<java.lang.Integer>, java.util.PrimitiveIterator<java.lang.Integer,​java.util.function.IntConsumer>, java.util.PrimitiveIterator.OfInt
    Direct Known Subclasses:
    IntIterators.AbstractIndexBasedListIterator
    Enclosing class:
    IntIterators

    public abstract static class IntIterators.AbstractIndexBasedIterator
    extends AbstractIntIterator
    A skeletal implementation for an iterator backed by an index-based data store. High performance concrete implementations (like the main Iterator 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 BigListIterators 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).

    • Nested Class Summary

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

        java.util.PrimitiveIterator.OfDouble, java.util.PrimitiveIterator.OfInt, java.util.PrimitiveIterator.OfLong
    • Method Detail

      • hasNext

        public boolean hasNext()
      • nextInt

        public int nextInt()
        Description copied from interface: IntIterator
        Returns the next element as a primitive type.
        Returns:
        the next element in the iteration.
        See Also:
        Iterator.next()
      • remove

        public void remove()
      • forEachRemaining

        public void forEachRemaining​(java.util.function.IntConsumer action)
      • skip

        public int skip​(int n)
        Description copied from interface: IntIterator
        Skips the given number of elements.

        The effect of this call is exactly the same as that of calling IntIterator.next() for n times (possibly stopping if Iterator.hasNext() becomes false).

        Parameters:
        n - the number of elements to skip.
        Returns:
        the number of elements actually skipped.
        See Also:
        Iterator.next()