How To Iterate LinkedList In Java?

In this tutorial, we will see how to iterate LinkedList in Java. There are multiple ways to iterate such as loops, using Iterator or using Java 8 syntax. Let’s see these ways to iterate over LinkedList in Java.

Introduction

The LinkedList class is present in the java.util package.

LinkedList internally uses a doubly LinkedList for storing the variables. That’s why LinkedList is preferred when our frequent operation is insertion and deletion.

There are multiple ways to iterate over the LinkedList. We will see the following ways

  1. Iterate the LinkedList using basic for loop
  2. Iterate the LinkedList using Enhanced For Loop i.e. For-each loop
  3. Iterate the LinkedList using the while loop
  4. Iterate the LinkedList using Iterator
  5. Iterate the LinkedList using Java 8 the forEach() Method

So let’s see all the options one by one.

1. Iterate the LinkedList using basic for-loop

We can write a simple for loop for the LinkedList and access the elements of the LinkedList using the get(int index) method.

Please refer to the following Java example to iterate over LinkedList using the basic for loop.

import java.util.LinkedList;
import java.util.List;

/**
 * A Java program to iterate over LinkedList
 * using the basic for loop.
 * 
 * @author coderolls.com
 *
 */
public class LinkedListForLoop {

  public static void main(String[] args) {
    List<String> linkedList = new LinkedList<String>();
    linkedList.add("Mango");
    linkedList.add("Banana");
    linkedList.add("Grapes");
    linkedList.add("Watermelon");
    linkedList.add("Apple");
    linkedList.add("Avocado");
    
    System.out.println("Iterating through LinkedList using the basic for loop!\n");
    
    int len = linkedList.size();
    
    // iterate over linkedList using basic for loop
    for (int i = 0; i < len; i++) {
      
      // get String object from linkedList at index i
      String str = linkedList.get(i);
      System.out.println("The object from the LinkedList at " + i + " is " + str);
    }
  }
}

Output:

Iterating through LinkedList using the basic for loop.......

The object from the LinkedList at 0 is Mango
The object from the LinkedList at 1 is Banana
The object from the LinkedList at 2 is Grapes
The object from the LinkedList at 3 is Watermelon
The object from the LinkedList at 4 is Apple
The object from the LinkedList at 5 is Avocado

2. Iterate the LinkedList using Enhanced For Loop i.e. For-each loop

Here we will use the foreach loop i.e. Enhanced For Loop to iterate through ArrayList.

Let us understand the syntax for the Enhanced For Loop.

for(DataType item:Array | Collection){
// operate on the item here
}

Please refer to the following Java program to iterate over LinkedList using the foreach loop.

import java.util.LinkedList;
import java.util.List;

/**
 * A Java program to iterate over LinkedList
 * using the foreach loop.
 * 
 * @author coderolls.com
 *
 */
public class LinkedListForeachLoop {

  public static void main(String[] args) {
    List<String> linkedList = new LinkedList<String>();
    
    linkedList.add("Mango");
    linkedList.add("Banana");
    linkedList.add("Grapes");
    linkedList.add("Watermelon");
    linkedList.add("Apple");
    linkedList.add("Avocado");
    
    System.out.println("Iterating through LinkedList using the foreach loop!\n");
    
    // iterate over linkedList using for-each loop
    for (String str: linkedList) {
      System.out.println("The object from the LinkedList is "+str);
    }
  }
}

Output:

Iterating through LinkedList using the for-each loop!

The object from the LinkedList is Mango
The object from the LinkedList is Banana
The object from the LinkedList is Grapes
The object from the LinkedList is Watermelon
The object from the LinkedList is Apple
The object from the LinkedList is Avocado

3. Iterate the LinkedList using the while loop

Similar to the for and for-each loop, we can also use the while loop to iterate over LinkedList.

I have given a Java program below to iterate over LinkedList using the while loop.

/**
 * A Java program to iterate over LinkedList
 * using the while loop.
 * 
 * @author coderolls.com
 *
 */
public class LinkedListWhileLoop {

  public static void main(String[] args) {
  
    List<String> linkedList = new LinkedList<String>();
    
    linkedList.add("Mango");
    linkedList.add("Banana");
    linkedList.add("Grapes");
    linkedList.add("Watermelon");
    linkedList.add("Apple");
    linkedList.add("Avocado");
    
    System.out.println("Iterating through LinkedList using the while loop!\n");
    
    int len = linkedList.size();
    
    // iterate over linkedList using the while loop
    int i =0;
    
    while(i<len) {
      // get String object from linkedList at index i
      String str = linkedList.get(i);
      
      System.out.println("Object form the LinkedList is "+str);
      //increment index after getting the object
      i++;
    }
  }
}

Output:

Iterating through LinkedList using the while loop!

The object from the LinkedList is Mango
The object from the LinkedList is Banana
The object from the LinkedList is Grapes
The object from the LinkedList is Watermelon
The object from the LinkedList is Apple
The object from the LinkedList is Avocado

4. Iterate the LinkedList using Iterator

Iterator is an interface in Java. We can use an Iterator to iterate over a collection.

It is present in the java.util package.

If we want to iterate over a LinkedList using an iterator, we should invoke the iterator() method on the LinkedList object to get the iterator reference as given below

// linkedList is a LinkedList object
Iterator iterator = linkedList.iterator();

Iterator has three important methods. They are as given below.

hasNext() - This method checks if the collection has any object available next, if found it will return true else false

next() - This method returns the next object from the LinkedList.

remove() - This method removes the object from the LinkedList

I have given a Java program below to iterate over a LinkedList using the iterator interface. We will be using the hasNext() and next() methods in the program.

import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;

/**
 * A Java program to iterate through LinkedList using the Iterator interface.
 * 
 * @author coderolls.com
 *
 */
public class LinkedListIterator {

  public static void main(String[] args) {
    List<String> linkedList = new LinkedList<String>();
    linkedList.add("Mango");
    linkedList.add("Banana");
    linkedList.add("Grapes");
    linkedList.add("Watermelon");
    linkedList.add("Apple");
    linkedList.add("Avocado");
    System.out.println("Iterating through LinkedList using Iterator interface........\n");
    
    // getting an iterator
    Iterator<String> iterator = linkedList.iterator();
    
    // hasNext() returns true only if the object is available at the next call
    while (iterator.hasNext()) {
      // next() returns the object, we can cast it to the required type
      String str = iterator.next();
      System.out.println("The object from the LinkedList is " + str);
    }
  }
}

Output:

Iterating through LinkedList using Iterator interface........

The object from the LinkedList is Mango
The object from the LinkedList is Banana
The object from the LinkedList is Grapes
The object from the LinkedList is Watermelon
The object from the LinkedList is Apple
The object from the LinkedList is Avocado

Note: It is always recommended to use the Iterator.remove() method for removing an element from a list while iterating on it. Also, we have the remove() method in the LinkedList class, if you use the LinkedList.remove() method to remove an element while iterating over the list, you will get the ConcurrentModificationException.

5. Iterate the LinkedList using ListIterator

I have written a detailed article on the ListIterator method of the LinkedList class. Read LinkedList listIterator() method in Java

6. Iterate the LinkedList using Java 8 forEach() Method

In Java 8, we got the new forEach() method to iterator over collections.

Inside the forEach() method, we can write the lambda expression for the Consumer functional interface.

I have given a sample Java program below to iterate over the LinkedList using the forEach() method.

import java.util.LinkedList;
import java.util.List;

/**
 * A Java program to iterate over LinkedList
 * using the java 8 forEach() method.
 * 
 * @author coderolls.com
 */
public class LinkedListForEachMethod {

  public static void main(String[] args) {
    List<String> linkedList = new LinkedList<String>();
    linkedList.add("Mango");
    linkedList.add("Banana");
    linkedList.add("Grapes");
    linkedList.add("Watermelon");
    linkedList.add("Apple");
    linkedList.add("Avocado");
    
    System.out.println("Iterating through LinkedList using forEach method and lamda expression........\n");
    
    //Add lambda expression in the forEach() method
    linkedList.forEach(s -> System.out.println("The object from the LinkedList is " + s));
  }
}

Output:

Iterating through LinkedList using forEach method and lambda expression........

The object from the LinkedList is Mango
The object from the LinkedList is Banana
The object from the LinkedList is Grapes
The object from the LinkedList is Watermelon
The object from the LinkedList is Apple
The object from the LinkedList is Avocado

Conclusion

We can iterate over ArrayList using the following ways.

  1. Iterating the ArrayList using basic for loop

    int len = linkedList.size();
    for (int i = 0; i < len; i++) {
        String str = linkedList.get(i);
        System.out.println("Object form the LinkedList at " + i + " is " + str);
    }
    
  2. Iterating the ArrayList using Enhanced For Loop i.e. For-each loop

    for (String str: linkedList) {
        System.out.println("Object form the LinkedList is "+str);
    }
    
  3. Iterating the ArrayList using a while loop

    int len = linkedList.size();
    int i =0;
       
    while(i<len) {
        String str = linkedList.get(i);
        System.out.println("Object form the LinkedList is "+str);
        i++;
    }
    
  4. Iterating the ArrayList using Iterator

    Iterator<String> iterator = linkedList.iterator();
       
    while (iterator.hasNext()) {
        String str = iterator.next();
        System.out.println("Object form the LinkedList is " + str);
    }
    
  5. Iterating the ArrayList using ListIterator- I have written a detailed article on the ListIterator method of the LinkedList class. Read LinkedList listIterator() method in Java

  6. Iterating the ArrayList using Java 8 forEach() Method

    linkedList.forEach(s -> System.out.println("Object form the LinkedList is " + s));
    

The example Java programs given in the above tutorial can be found at this GitHub Repository.

Let me know your thoughts or suggestions on the topic discussed above in the comment section below.