In this tutorial, we will see the subList()
method of the ArrayList class in Java. This method returns a view of the specified range within the list.
Introduction
ArrayList is a widely used class to store and retrieve data in a collection framework.
ArrayList is an ordered collection i.e. it maintains the insertion order of the elements. Also, it allows duplicate elements in the list.
Also, we have seen a few methods of the ArrayList class before like add()
, addAll()
, remove()
, set()
, iterate()
, clear()
, contains()
, get()
, removeRange()
and retainAll()
method.
Today we will see the subList(int fromIndex, int toIndex)
method.
ArrayList subList(int fromIndex, int toIndex)
method
The subList(int fromIndex, int toIndex)
method returns the view of the portion of this list between the specified fromIndex
, inclusive and toIndex
, exclusive.
The method signature is given below.
public List<E> subList(int fromIndex, int toIndex)
As shown in the method signature, the subList() method accepts two parameters of type int
i.e fromIndex
and toIndex
Parameter | Description |
---|---|
fromIndex |
low endpoint (inclusive) of the subList |
toIndex |
high endpoint (exclusive) of the subList |
Let’s see the Java program for a better understanding.
import java.util.ArrayList;
import java.util.List;
/**
* A java program to explain the subList() method of the ArrayList class in Java
*
* @author coderolls.com
*
*/
public class ArrayListSubListExample {
public static void main(String[] args) {
// create an empty ArrayList object 'states'
List<String> states = new ArrayList<String>();
// add state in the ArrayList
states.add("California");
states.add("Texas");
states.add("Florida");
states.add("New Jersey");
states.add("Washington");
System.out.println("The states list: \n"+ states);
//Sublist the states list from 1 to 3 index
List<String> statesSubList = states.subList(1, 3);
System.out.println("\nThe states sublist from index 1 (inclusive) to 3 (exclusive): \n"+ statesSubList);
}
}
Output:
The states list:
[California, Texas, Florida, New Jersey, Washington]
The states sublist from index 1 (inclusive) to 3 (exclusive):
[Texas, Florida]
Exceptions thrown by subList()
Methods
This method may throw the ClassCastException
and NullPointerException
.
IndexOutOfBoundsException
This method may throw the ClassCastException
, if an endpoint index value is out of range. i.e. if fromIndex
is less than 0
(fromIndex < 0
) or toIndex
is greater than the size of the ArrayList (toIndex > size
).
The Java example for the IndexOutOfBoundsException
is given below.
/**
* A Java program to explain the subList() methods
* IndexOutOfBoundsException exception case.
*
* @author coderolls.com
*/
public class SubListMethodExceptionExample1 {
public static void main(String[] args) {
// create an empty ArrayList object 'states'
List<String> states = new ArrayList<String>();
// add state in the ArrayList
states.add("California");
states.add("Texas");
states.add("Florida");
states.add("New Jersey");
states.add("Washington");
System.out.println("The states list: \n"+ states);
// will throw IndexOutOfBoundsException
List<String> statesSubList = states.subList(1, 7); // will throw exception
System.out.println("\nThe states sublist from index 1 (inclusive) to 3 (exclusive): \n"+ statesSubList);
}
}
Output:
The states list:
[California, Texas, Florida, New Jersey, Washington]
Exception in thread "main" java.lang.IndexOutOfBoundsException: toIndex = 7
at java.util.ArrayList.subListRangeCheck(ArrayList.java:1012)
at java.util.ArrayList.subList(ArrayList.java:1004)
at com.gaurav.ExProject.ArrayList.SubListMethodExceptionExample1.main(SubListMethodExceptionExample1.java:22)
IllegalArgumentException
This method may throw the NullPointerException
, if the endpoint indices are out of order. i.e. if the fromIndex
is greater than toIndex
The Java example for the IllegalArgumentException
is given below.
/**
* A Java program to explain the subList() methods
* IllegalArgumentException exception case.
*
* @author coderolls.com
*/
public class SubListMethodExceptionExample2 {
public static void main(String[] args) {
// create an empty ArrayList object 'states'
List<String> states = new ArrayList<String>();
// add state in the arraylist
states.add("California");
states.add("Texas");
states.add("Florida");
states.add("New Jersey");
states.add("Washington");
System.out.println("The states list: \n"+ states);
// will throw IllegalArgumentException
List<String> statesSubList = states.subList(3, 1);
System.out.println("\nThe states sublist from index 1 (inclusive) to 3 (exclusive): \n"+ statesSubList);
}
}
Output:
The states list:
[California, Texas, Florida, New Jersey, Washington]
Exception in thread "main" java.lang.IllegalArgumentException: fromIndex(3) > toIndex(1)
at java.util.ArrayList.subListRangeCheck(ArrayList.java:1014)
at java.util.ArrayList.subList(ArrayList.java:1004)
at com.gaurav.ExProject.ArrayList.SubListMethodExceptionExample2.main(SubListMethodExceptionExample2.java:28)
Conclusion
public List<E> subList(int fromIndex, int toIndex)
The subList(int fromIndex, int toIndex)
method returns the view of the portion of this list between the specified fromIndex
, inclusive and toIndex
, exclusive.
The example Java program used in the above article can be found at this GitHub repository.
Please write your thoughts in the comment section below.