Class CursorableLinkedList.Cursor<E>
- java.lang.Object
-
- org.apache.commons.collections4.list.AbstractLinkedList.LinkedListIterator<E>
-
- org.apache.commons.collections4.list.CursorableLinkedList.Cursor<E>
-
- All Implemented Interfaces:
java.util.Iterator<E>,java.util.ListIterator<E>,OrderedIterator<E>
- Direct Known Subclasses:
CursorableLinkedList.SubCursor
- Enclosing class:
- CursorableLinkedList<E>
public static class CursorableLinkedList.Cursor<E> extends AbstractLinkedList.LinkedListIterator<E>
An extendedListIteratorthat allows concurrent changes to the underlying list.
-
-
Field Summary
-
Fields inherited from class org.apache.commons.collections4.list.AbstractLinkedList.LinkedListIterator
current, expectedModCount, next, nextIndex, parent
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedCursor(CursorableLinkedList<E> parent, int index)Constructs a new cursor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidadd(E obj)Adds an object to the list.protected voidcheckModCount()Override superclass modCount check, and replace it with our valid flag.voidclose()Mark this cursor as no longer being needed.intnextIndex()Gets the index of the next element to be returned.protected voidnodeChanged(AbstractLinkedList.Node<E> node)Handle event from the list when a node has changed.protected voidnodeInserted(AbstractLinkedList.Node<E> node)Handle event from the list when a node has been added.protected voidnodeRemoved(AbstractLinkedList.Node<E> node)Handle event from the list when a node has been removed.voidremove()Removes the item last returned by this iterator.-
Methods inherited from class org.apache.commons.collections4.list.AbstractLinkedList.LinkedListIterator
getLastNodeReturned, hasNext, hasPrevious, next, previous, previousIndex, set
-
-
-
-
Constructor Detail
-
Cursor
protected Cursor(CursorableLinkedList<E> parent, int index)
Constructs a new cursor.- Parameters:
parent- the parent listindex- the index to start from
-
-
Method Detail
-
remove
public void remove()
Removes the item last returned by this iterator.There may have been subsequent alterations to the list since you obtained this item, however you can still remove it. You can even remove it if the item is no longer in the main list. However, you can't call this method on the same iterator more than once without calling next() or previous().
- Specified by:
removein interfacejava.util.Iterator<E>- Specified by:
removein interfacejava.util.ListIterator<E>- Overrides:
removein classAbstractLinkedList.LinkedListIterator<E>- Throws:
java.lang.IllegalStateException- if there is no item to remove
-
add
public void add(E obj)
Adds an object to the list. The object added here will be the new 'previous' in the iterator.- Specified by:
addin interfacejava.util.ListIterator<E>- Overrides:
addin classAbstractLinkedList.LinkedListIterator<E>- Parameters:
obj- the object to add
-
nextIndex
public int nextIndex()
Gets the index of the next element to be returned.- Specified by:
nextIndexin interfacejava.util.ListIterator<E>- Overrides:
nextIndexin classAbstractLinkedList.LinkedListIterator<E>- Returns:
- the next index
-
nodeChanged
protected void nodeChanged(AbstractLinkedList.Node<E> node)
Handle event from the list when a node has changed.- Parameters:
node- the node that changed
-
nodeRemoved
protected void nodeRemoved(AbstractLinkedList.Node<E> node)
Handle event from the list when a node has been removed.- Parameters:
node- the node that was removed
-
nodeInserted
protected void nodeInserted(AbstractLinkedList.Node<E> node)
Handle event from the list when a node has been added.- Parameters:
node- the node that was added
-
checkModCount
protected void checkModCount()
Override superclass modCount check, and replace it with our valid flag.- Overrides:
checkModCountin classAbstractLinkedList.LinkedListIterator<E>
-
close
public void close()
Mark this cursor as no longer being needed. Any resources associated with this cursor are immediately released. In previous versions of this class, it was mandatory to close all cursor objects to avoid memory leaks. It is no longer necessary to call this close method; an instance of this class can now be treated exactly like a normal iterator.
-
-