Class ObjectArrayListIterator

java.lang.Object
org.apache.commons.collections.iterators.ObjectArrayIterator
org.apache.commons.collections.iterators.ObjectArrayListIterator
All Implemented Interfaces:
Iterator, ListIterator, ResettableIterator, ResettableListIterator

@Deprecated(since="2021-04-30") public class ObjectArrayListIterator extends ObjectArrayIterator implements ListIterator, ResettableListIterator
Deprecated.
Apache Commons Collections version 3.x is being deprecated from AEMaaCS. The upgraded version 4.4 of Commons Collections is already included as replacement. Customers are advised to upgrade to this version of the library. Please note: the package name was changed to org.apache.commons.collections4. Further note that there are AEM APIs currently exposing the old collections classes; these will be updated in upcoming releases.
Implements a ListIterator over an array of objects.

This iterator does not support add(java.lang.Object) or ObjectArrayIterator.remove(), as the object array cannot be structurally modified. The set(java.lang.Object) method is supported however.

The iterator implements a reset() method, allowing the reset of the iterator back to the start if required.

Since:
Commons Collections 3.0
See Also:
  • Constructor Details

    • ObjectArrayListIterator

      public ObjectArrayListIterator()
      Deprecated.
      Constructor for use with setArray.

      Using this constructor, the iterator is equivalent to an empty iterator until ObjectArrayIterator.setArray(java.lang.Object[]) is called to establish the array to iterate over.

    • ObjectArrayListIterator

      public ObjectArrayListIterator(Object[] array)
      Deprecated.
      Constructs an ObjectArrayListIterator that will iterate over the values in the specified array.
      Parameters:
      array - the array to iterate over
      Throws:
      NullPointerException - if array is null
    • ObjectArrayListIterator

      public ObjectArrayListIterator(Object[] array, int start)
      Deprecated.
      Constructs an ObjectArrayListIterator that will iterate over the values in the specified array from a specific start index.
      Parameters:
      array - the array to iterate over
      start - the index to start iterating at
      Throws:
      NullPointerException - if array is null
      IndexOutOfBoundsException - if the start index is out of bounds
    • ObjectArrayListIterator

      public ObjectArrayListIterator(Object[] array, int start, int end)
      Deprecated.
      Construct an ObjectArrayListIterator that will iterate over a range of values in the specified array.
      Parameters:
      array - the array to iterate over
      start - the index to start iterating at
      end - the index (exclusive) to finish iterating at
      Throws:
      IndexOutOfBoundsException - if the start or end index is out of bounds
      IllegalArgumentException - if end index is before the start
      NullPointerException - if array is null
  • Method Details

    • hasPrevious

      public boolean hasPrevious()
      Deprecated.
      Returns true if there are previous elements to return from the array.
      Specified by:
      hasPrevious in interface ListIterator
      Returns:
      true if there is a previous element to return
    • previous

      public Object previous()
      Deprecated.
      Gets the previous element from the array.
      Specified by:
      previous in interface ListIterator
      Returns:
      the previous element
      Throws:
      NoSuchElementException - if there is no previous element
    • next

      public Object next()
      Deprecated.
      Gets the next element from the array.
      Specified by:
      next in interface Iterator
      Specified by:
      next in interface ListIterator
      Overrides:
      next in class ObjectArrayIterator
      Returns:
      the next element
      Throws:
      NoSuchElementException - if there is no next element
    • nextIndex

      public int nextIndex()
      Deprecated.
      Gets the next index to be retrieved.
      Specified by:
      nextIndex in interface ListIterator
      Returns:
      the index of the item to be retrieved next
    • previousIndex

      public int previousIndex()
      Deprecated.
      Gets the index of the item to be retrieved if previous() is called.
      Specified by:
      previousIndex in interface ListIterator
      Returns:
      the index of the item to be retrieved next
    • add

      public void add(Object obj)
      Deprecated.
      This iterator does not support modification of its backing array's size, and so will always throw an UnsupportedOperationException when this method is invoked.
      Specified by:
      add in interface ListIterator
      Parameters:
      obj - the object to add
      Throws:
      UnsupportedOperationException - always thrown.
    • set

      public void set(Object obj)
      Deprecated.
      Sets the element under the cursor.

      This method sets the element that was returned by the last call to next() of previous(). Note: ListIterator implementations that support add() and remove() only allow set() to be called once per call to next() or previous (see the ListIterator javadoc for more details). Since this implementation does not support add() or remove(), set() may be called as often as desired.

      Specified by:
      set in interface ListIterator
      Parameters:
      obj - the object to set into the array
      Throws:
      IllegalStateException - if next() has not yet been called.
      ClassCastException - if the object type is unsuitable for the array
    • reset

      public void reset()
      Deprecated.
      Resets the iterator back to the start index.
      Specified by:
      reset in interface ResettableIterator
      Specified by:
      reset in interface ResettableListIterator
      Overrides:
      reset in class ObjectArrayIterator