Java - How to Use Iterator?
Iterator
Often, you will want to cycle through the elements in a collection. For example, you might want to display each element. The easiest way to do this is to employ an iterator, which is an object that implements either the Iterator or the ListIterator interface.
An iterator enables you to cycle through a collection, obtaining or removing elements. ListIterator extends Iterator to allow bidirectional traversal of a list and the modification of elements.
Before you can access a collection through an iterator, you must obtain one. Each of the collection classes provides an iterator( ) method that returns an iterator to the start of the collection. By using this iterator object, you can access each element in the collection, one element at a time.
Syntax
The following is the syntax for declaring an iterator interface −
public interface Iterator<E>
Here, "E" is the type of the elements to be returned by this interface.
Using the Iterator Interface
In general, to use an iterator to cycle through the contents of a collection, first import the java.util.Iterator library, and then follow these steps −
Step 1
Obtain an iterator to the start of the collection by calling the collection's iterator( ) method.
Iterator<Data_Type> iterator_Name = collection_Name.iterator();
Step 2
Set up a while loopthat makes a call to the hasNext( ) method. Have the loop iterate as long as hasNext( ) returns true.
while(iterator_Name.hasNext()){
//Operation to be performed
}
Step 3
Within the while loop, obtain each element by calling the next( ) method. Here, we are printing the elements of the Collection.
System.out.println(iterator_Name.next());
For collections that implement List, you can also obtain an iterator by calling ListIterator.
The Methods Declared by the Iterator Interface
The following are the methods supported by the iterator interface in Java −
| Sr.No. | Method & Description |
|---|---|
| 1 |
boolean hasNext( ) Returns true if there are more elements. Otherwise, returns false. |
| 2 |
Object next( ) Returns the next element. Throws NoSuchElementException if there is not a next element. |
| 3 |
void remove( ) Removes the current element. Throws IllegalStateException if an attempt is made to call remove( ) that is not preceded by a call to next( ). |
Example
Here is an example demonstrating an Iterator. It uses an ArrayList object, but the general principles apply to any type of collection.
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class IteratorDemo {
public static void main(String args[]) {
// Create an array list
List<String> al = new ArrayList<>();
// add elements to the array list
al.add("C");
al.add("A");
al.add("E");
al.add("B");
al.add("D");
al.add("F");
// Use iterator to display contents of al
System.out.print("Original contents of al: ");
Iterator<String> itr = al.iterator();
while(itr.hasNext()) {
Object element = itr.next();
System.out.print(element + " ");
}
System.out.println();
}
}
Output
Original contents of al: C A E B D F
Using the var Keyword for Iterator
The var keyword can be used instead of the Iterator<String> to avoid repeating the long type names, as this reduces the code. Since the var keyword was introduced in Java 10, it won't work in older Java versions.
Example
Below is an example to demonstrate the use of the var keyword with Iterators in Java −
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class IteratorDemo {
public static void main(String args[]) {
// Create an array list
List<String> al = new ArrayList<>();
// add elements to the array list
al.add("C");
al.add("A");
al.add("E");
al.add("B");
al.add("D");
al.add("F");
//use var keyword for iterator to display contents of al
System.out.print("Original contents of al: ");
var itr = al.iterator();
while(itr.hasNext()) {
System.out.print(itr.next() + " ");
}
System.out.println();
}
}
Output
Original contents of al: C A E B D F
ListIterator
The ListIterator is also a type of iterator that allows us to traverse the list in either direction, modify the list at iteration, and obtain the iterator's index in the list. ListIterator is available only to those collections that implement the List interface.
A ListIterator works on the cursor position, which lies between the element that would be returned by the previous() method and the element that would be returned by the next() method.
Syntax
The following represents the syntax for initializing a ListIterator in Java −
ListIterator<Data_Type> iterator_Name = List_Interface.listIterator();
The Methods Declared by ListIterator
The following are the methods supported by the ListIterator interface in Java −
| Sr.No. | Method & Description |
|---|---|
| 1 |
void add(Object obj) Inserts obj into the list in front of the element that will be returned by the next call to next( ). |
| 2 |
boolean hasNext( ) Returns true if there is a next element. Otherwise, returns false. |
| 3 |
boolean hasPrevious( ) Returns true if there is a previous element. Otherwise, returns false. |
| 4 |
Object next( ) Returns the next element. A NoSuchElementException is thrown if there is not a next element. |
| 5 |
int nextIndex( ) Returns the index of the next element. If there is not a next element, returns the size of the list. |
| 6 |
Object previous( ) Returns the previous element. A NoSuchElementException is thrown if there is not a previous element. |
| 7 |
int previousIndex( ) Returns the index of the previous element. If there is not a previous element, returns -1. |
| 8 |
void remove( ) Removes the current element from the list. An IllegalStateException is thrown if remove( ) is called before next( ) or previous( ) is invoked. |
| 9 |
void set(Object obj) Assigns obj to the current element. This is the element last returned by a call to either next( ) or previous( ). |
Example 1
Here is an example demonstrating ListIterator. It uses an ArrayList object, but the general principles apply to any type of collection.
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
public class IteratorDemo {
public static void main(String args[]) {
// Create an array list
List<String> al = new ArrayList<>();
// add elements to the array list
al.add("C");
al.add("A");
al.add("E");
al.add("B");
al.add("D");
al.add("F");
// Use iterator to display contents of al
System.out.print("Original contents of al: ");
Iterator<String> itr = al.iterator();
while(itr.hasNext()) {
Object element = itr.next();
System.out.print(element + " ");
}
}
}
Output
Original contents of al: C A E B D F
Example 2
Here is an example demonstrating ListIterator to modify the list while iterating. It uses an ArrayList object, but the general principles apply to any type of collection.
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
public class IteratorDemo {
public static void main(String args[]) {
// Create an array list
List<String> al = new ArrayList<>();
// add elements to the array list
al.add("C");
al.add("A");
al.add("E");
al.add("B");
al.add("D");
al.add("F");
// Use iterator to display contents of al
System.out.print("Original contents of al: ");
Iterator<String> itr = al.iterator();
while(itr.hasNext()) {
Object element = itr.next();
System.out.print(element + " ");
}
System.out.println();
// Modify objects being iterated
ListIterator<String> litr = al.listIterator();
while(litr.hasNext()) {
Object element = litr.next();
litr.set(element + "+");
}
System.out.print("Modified contents of al: ");
itr = al.iterator();
while(itr.hasNext()) {
Object element = itr.next();
System.out.print(element + " ");
}
System.out.println();
// Now, display the list backwards
System.out.print("Modified list backwards: ");
while(litr.hasPrevious()) {
Object element = litr.previous();
System.out.print(element + " ");
}
System.out.println();
}
}
Output
Original contents of al: C A E B D F Modified contents of al: C+ A+ E+ B+ D+ F+ Modified list backwards: F+ D+ B+ E+ A+ C+