The for-each loop in Java (also called the enhanced for loop) was introduced in Java 5 to simplify iteration over arrays and collections. It is cleaner and more readable than the traditional for loop and is commonly used when the exact index of an element is not required.
Example: Using a for-each loop to print each element of an array in Java.
Java
// Java Program to Iterate through an array
// Using for-each loop
import java.io.*;
class Geeks {
public static void main(String[] args) {
// Array declaration
int arr[] = { 1, 2, 3, 4, 5 };
// Using for-each loop to
// print each element
for (int e : arr) {
System.out.print(e + " ");
}
}
}
Explanation: In this example, the for-each loop iterates over the array "arr"
and prints each element. We use the variable element "e"
to access each value in the array, making the loop more concise compared to using a traditional for loop with an index.
Syntax of For-each Loop
for (type var : array) {
statements using var;
}
Parameters:
- type: The data type of the elements in the array or collection.
- var: The variable that holds the current element during each iteration.
- array: The array or collection being iterated over.
When to Use For-Each Loop?
Use for-each loop when:
- There is no need to access the index of the elements
- Code readability is a priority.
When to Avoid For-Each Loop?
Avoid using for-each loop when:
- You need to access element by their index.
- Perform reverse iteration.
- Directly want to modify element in primitive arrays.
Finding Maximum in an Array using for-each Loop
Example: This example demonstrates how to find the maximum value in an integer array using a for-each loop.
Java
// Java Program to find maximum in an array
// Using for-each loop
public class Geeks {
public static void main(String[] args) {
int[] mark = {125, 132, 95, 116, 110};
int max = findMax(mark);
System.out.println("" + max);
}
public static int findMax(int[] n) {
int maximum = n[0];
// Iterates through the array
for (int n1: n) {
if (n1 > maximum) {
maximum = n1;
}
}
return maximum;
}
}
Explanation: In the above example, we create a method findMax(). This method takes an array and then we assume the first element as mas and then use the for-each to iterate each element of the array and compare it with the max, if it is greater than the max then update the max value.
Iterating in a List using for-each loop
Example: This example demonstrates how to find the maximum element in a list using a for-each loop.
Java
// Java program to iterate through a list of Integers
// using for-each loop and find the maximum element
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
class Geeks
{
public static void main(String[] args)
{
// List of Integers
List<Integer> l = new ArrayList<>();
l.add(3);
l.add(5);
l.add(7);
l.add(9);
// Minimum Integer value as max
int max = Integer.MIN_VALUE;
// Using for-each loop
// to find maximum element
for(Integer i: l)
{
// check if current element is greater than max
if(i > max)
{
// update max
max = i;
}
}
System.out.println("List of Integers " + l);
System.out.println("Maximum elemen in a list is: " + max);
}
}
OutputList of Integers [3, 5, 7, 9]
Maximum elemen in a list is: 9
Explanation: In the above example, we use the for-each loop to iterate the list of integer to find the largest or maximum value in the list. Here, we use the Integer.MIN_VALUE which is the minimum value of integer and compare it the element of list and check if the element is greater than the max then update the max value.
Limitations of the For-each Loop
While the for-each loop is convenient, there are some important limitations to consider:
1. Cannot Modify Array Elements Directly
for (int num : marks) {
// only changes num, not the array element
num = num*2;
}
Explanation: The for-each loop gives a copy of each element, not a reference. So modifying the loop variable (num
in this case) does not affect the actual array or collection. For objects, the loop variable is a reference, so modifying fields of the object will affect the original.
class Person { String name; }
Person[] people = { new Person("Jeeva") };
for (Person p : people) {
p.name = "Devanshu"; // Changes original object
p = new Person(); // Does NOT modify array
}
2. No Access to Index
for (int num : numbers) {
if (num == target) {
// do not know the index of 'num' here
return ???; // Index is unavailable in for-each loop
}
}
Explanation: The for-each loop does not provide access to the index of the current element. If we need the index for any reason (e.g., in a search operation), a traditional loop would be more appropriate.
3. Single-direction Iteration Only
// Traditional reverse iteration
for (int i = numbers.length - 1; i >= 0; i--) {
System.out.println(numbers[i]); // Reverse iteration not possible with for-each
}
Explanation: The for-each loop only iterates over the elements in a forward direction. If we need to iterate in reverse, we have to use a traditional for loop with a manually managed index.
Workaround for Collections:
List<Integer> list = Arrays.asList(1, 2, 3);
Collections.reverse(list); // Reverse first
for (int num : list) { ... } // Now iterates backward
4. Complex Conditions are Difficult to Implement
for (int i = 0; i < numbers.length; i++) {
if (numbers[i] == arr[i]) {
// Complex conditional checks are easier in a traditional for loop
}
}
Explanation: If our logic requires checking multiple conditions or using the index in more complex ways, the for-each loop can be limiting. In such cases, a traditional for loop offers more flexibility.
5. Performance Overhead
// For reliable benchmarks, use JMH instead of manual timing.
List<Integer> list = new ArrayList<>();
for (int i = 0; i < 1_000_000; i++) list.add(i);
// For-each (iterator-based)
long start = System.nanoTime();
for (int num : list) { ... }
long end = System.nanoTime();
System.out.println("For-each: " + (end - start) + " ns");
// Traditional for (index-based)
start = System.nanoTime();
for (int i = 0; i < list.size(); i++) { ... }
end = System.nanoTime();
System.out.println("Traditional: " + (end - start) + " ns");
Explanation: The for-each loop uses an iterator for collections (e.g., ArrayList), which adds slight overhead. For arrays, Java optimizes it to a traditional loop.
Example: This example demonstrates a performance comparison between loop types for iterating over a large list.
Java
// Java program to compare the performance of
// different loop types for
// iterating over a large list
import java.io.*;
import java.util.*;
class Geeks
{
public static void main(String[] args)
{
List<Integer> list = new ArrayList<>();
long startTime;
long endTime;
// Adding 1 million integers to the list
for (int i = 0; i < 1000000; i++)
{
list.add(i);
}
// Type 1: Using a for-each loop
startTime = Calendar.getInstance().getTimeInMillis();
for (int i : list)
{
// Looping over each element
int a = i;
}
endTime = Calendar.getInstance().getTimeInMillis();
System.out.println("For each loop :: " + (endTime - startTime) + " ms");
// Type 2: Using list.size() in the loop condition (with precomputation)
startTime = Calendar.getInstance().getTimeInMillis();
int size = list.size();
for (int j = 0; j < size; j++)
{
// Accessing list elements using index
int a = list.get(j);
}
endTime = Calendar.getInstance().getTimeInMillis();
System.out.println("Using collection.size() (precomputed) :: " +
(endTime - startTime) + " ms");
// Type 3: Calculating the collection size before the loop (already optimized)
startTime = Calendar.getInstance().getTimeInMillis();
for (int j = 0; j < size; j++)
{
// Accessing list elements using index
int a = list.get(j);
}
endTime = Calendar.getInstance().getTimeInMillis();
System.out.println("By calculating collection.size() first :: " +
(endTime - startTime) + " ms");
// Type 4: Iterating the list in reverse order
startTime = Calendar.getInstance().getTimeInMillis();
for (int j = size - 1; j >= 0; j--) {
// Accessing list elements in reverse
int a = list.get(j);
}
endTime = Calendar.getInstance().getTimeInMillis();
System.out.println("Using [int j = size - 1; j >= 0; j--] (precomputed) :: " +
(endTime - startTime) + " ms");
}
}
OutputFor each loop :: 40 ms
Using collection.size() (precomputed) :: 23 ms
By calculating collection.size() first :: 19 ms
Using [int j = size - 1; j >= 0; j--] (precomputed) :: 16 ms
Explanation: Each time we run the above code, it will give a different output because the execution and the performance times depend on different factors when JVM starts it takes time to optimize so it might appear that the loops work differently. as mentioned the for-each loop uses iterator internally which make a slight performance overhead compared to the traditional for loop.
Important Points:
- The loop starts with the keyword for like a normal for-loop.
- Instead of declaring and initializing a loop counter variable, we declare a variable that is the same type as the base type of the array, followed by a colon, which is then followed by the array name.
- In the loop body, we can use the loop variable we created rather than using an indexed array element.
- It is commonly used to iterate over an array or a Collections class (e.g., ArrayList)
Similar Reads
Basics of Java
Learn Java - A Beginners Guide for 2024If you are new to the world of coding and want to start your coding journey with Java, then this learn Java a beginners guide gives you a complete overview of how to start Java programming. Java is among the most popular and widely used programming languages and platforms. A platform is an environme
10 min read
Introduction to JavaJava is a high-level, object-oriented programming language developed by Sun Microsystems in 1995. It is platform-independent, which means we can write code once and run it anywhere using the Java Virtual Machine (JVM). Java is mostly used for building desktop applications, web applications, Android
4 min read
Similarities and Difference between Java and C++Nowadays Java and C++ programming languages are vastly used in competitive coding. Due to some awesome features, these two programming languages are widely used in industries as well as competitive programming. C++ is a widely popular language among coders for its efficiency, high speed, and dynamic
6 min read
Setting up Environment Variables For Java - Complete Guide to Set JAVA_HOMEIn the journey to learning the Java programming language, setting up environment variables for Java is essential because it helps the system locate the Java tools needed to run the Java programs. Now, this guide on how to setting up environment variables for Java is a one-place solution for Mac, Win
6 min read
Java SyntaxJava is an object-oriented programming language that is known for its simplicity, portability, and robustness. The syntax of Java programming language is very closely aligned with C and C++, which makes it easier to understand. Java Syntax refers to a set of rules that define how Java programs are w
6 min read
Java Hello World ProgramJava is one of the most popular and widely used programming languages and platforms. In this article, we will learn how to write a simple Java Program. This article will guide you on how to write, compile, and run your first Java program. With the help of Java, we can develop web and mobile applicat
6 min read
Differences Between JDK, JRE and JVMUnderstanding the difference between JDK, JRE, and JVM plays a very important role in understanding how Java works and how each component contributes to the development and execution of Java applications. The main difference between JDK, JRE, and JVM is:JDK: Java Development Kit is a software develo
3 min read
How JVM Works - JVM ArchitectureJVM (Java Virtual Machine) runs Java applications as a run-time engine. JVM is the one that calls the main method present in a Java code. JVM is a part of JRE (Java Runtime Environment). Java applications are called WORA (Write Once Run Anywhere). This means a programmer can develop Java code on one
7 min read
Java IdentifiersAn identifier in Java is the name given to Variables, Classes, Methods, Packages, Interfaces, etc. These are the unique names used to identify programming elements. Every Java Variable must be identified with a unique name.Example:public class Test{ public static void main(String[] args) { int a = 2
2 min read
Variables & DataTypes in Java
Java VariablesIn Java, variables are containers that store data in memory. Understanding variables plays a very important role as it defines how data is stored, accessed, and manipulated.Key Components of Variables in Java:A variable in Java has three components, which are listed below:Data Type: Defines the kind
9 min read
Scope of Variables in JavaThe scope of variables is the part of the program where the variable is accessible. Like C/C++, in Java, all identifiers are lexically (or statically) scoped, i.e., scope of a variable can be determined at compile time and independent of the function call stack. In this article, we will learn about
7 min read
Java Data TypesJava is statically typed and also a strongly typed language because each type of data, such as integer, character, hexadecimal, packed decimal etc. is predefined as part of the programming language, and all constants or variables defined for a given program must be declared with the specific data ty
14 min read
Operators in Java
Java OperatorsJava operators are special symbols that perform operations on variables or values. These operators are essential in programming as they allow you to manipulate data efficiently. They can be classified into different categories based on their functionality. In this article, we will explore different
15 min read
Java Arithmetic Operators with ExamplesOperators constitute the basic building block to any programming language. Java too provides many types of operators which can be used according to the need to perform various calculations and functions, be it logical, arithmetic, relational, etc. They are classified based on the functionality they
6 min read
Java Assignment Operators with ExamplesOperators constitute the basic building block of any programming language. Java too provides many types of operators which can be used according to the need to perform various calculations and functions, be it logical, arithmetic, relational, etc. They are classified based on the functionality they
7 min read
Java Unary Operator with ExamplesOperators constitute the basic building block to any programming language. Java too provides many types of operators which can be used according to the need to perform various calculations and functions be it logical, arithmetic, relational, etc. They are classified based on the functionality they p
8 min read
Java Relational Operators with ExamplesOperators constitute the basic building block to any programming language. Java too provides many types of operators which can be used according to the need to perform various calculations and functions, be it logical, arithmetic, relational, etc. They are classified based on the functionality they
10 min read
Java Logical Operators with ExamplesLogical operators are used to perform logical "AND", "OR", and "NOT" operations, i.e., the functions similar to AND gate and OR gate in digital electronics. They are used to combine two or more conditions/constraints or to complement the evaluation of the original condition under particular consider
8 min read
Java Ternary OperatorOperators constitute the basic building block of any programming language. Java provides many types of operators that can be used according to the need to perform various calculations and functions, be it logical, arithmetic, relational, etc. They are classified based on the functionality they provi
5 min read
Bitwise Operators in JavaIn Java, Operators are special symbols that perform specific operations on one or more than one operands. They build the foundation for any type of calculation or logic in programming.There are so many operators in Java, among all, bitwise operators are used to perform operations at the bit level. T
6 min read
Packages in Java
Flow Control in Java
Loops in Java
Jump Statements in Java
Arrays in Java
Arrays in JavaArrays in Java are one of the most fundamental data structures that allow us to store multiple values of the same type in a single variable. They are useful for storing and managing collections of data. Arrays in Java are objects, which makes them work differently from arrays in C/C++ in terms of me
15+ min read
Java Multi-Dimensional ArraysMultidimensional arrays are used to store the data in rows and columns, where each row can represent another individual array are multidimensional array. It is also known as array of arrays. The multidimensional array has more than one dimension, where each row is stored in the heap independently. T
10 min read
Jagged Array in JavaIn Java, a Jagged array is an array that holds other arrays. When we work with a jagged array, one thing to keep in mind is that the inner array can be of different lengths. It is like a 2D array, but each row can have a different number of elements.Example:arr [][]= { {10,20}, {30,40,50,60},{70,80,
6 min read
Strings in Java
Java StringsIn Java, a String is the type of object that can store a sequence of characters enclosed by double quotes, and every character is stored in 16 bits, i.e., using UTF 16-bit encoding. A string acts the same as an array of characters. Java provides a robust and flexible API for handling strings, allowi
9 min read
String Class in JavaA string is a sequence of characters. In Java, objects of the String class are immutable, which means they cannot be changed once created. In this article, we are going to learn about the String class in Java.Example of String Class in Java:Java// Java Program to Create a String import java.io.*; cl
7 min read
StringBuffer Class in JavaThe StringBuffer class in Java represents a sequence of characters that can be modified, which means we can change the content of the StringBuffer without creating a new object every time. It represents a mutable sequence of characters.Features of StringBuffer ClassThe key features of StringBuffer c
11 min read
Java StringBuilder ClassIn Java, the StringBuilder class is a part of the java.lang package that provides a mutable sequence of characters. Unlike String (which is immutable), StringBuilder allows in-place modifications, making it memory-efficient and faster for frequent string operations.Declaration:StringBuilder sb = new
7 min read
OOPS in Java
Java OOP(Object Oriented Programming) ConceptsJava Object-Oriented Programming (OOPs) is a fundamental concept in Java that every developer must understand. It allows developers to structure code using classes and objects, making it more modular, reusable, and scalable.The core idea of OOPs is to bind data and the functions that operate on it,
13 min read
Classes and Objects in JavaIn Java, classes and objects are basic concepts of Object Oriented Programming (OOPs) that are used to represent real-world concepts and entities. The class represents a group of objects having similar properties and behavior, or in other words, we can say that a class is a blueprint for objects, wh
11 min read
Java MethodsJava Methods are blocks of code that perform a specific task. A method allows us to reuse code, improving both efficiency and organization. All methods in Java must belong to a class. Methods are similar to functions and expose the behavior of objects.Example: Java program to demonstrate how to crea
8 min read
Access Modifiers in JavaIn Java, access modifiers are essential tools that define how the members of a class, like variables, methods, and even the class itself can be accessed from other parts of our program. They are an important part of building secure and modular code when designing large applications. Understanding de
7 min read
Wrapper Classes in JavaA Wrapper class in Java is one whose object wraps or contains primitive data types. When we create an object in a wrapper class, it contains a field, and in this field, we can store primitive data types. In other words, we can wrap a primitive value into a wrapper class object. Let's check on the wr
6 min read
Need of Wrapper Classes in JavaFirstly the question that hits the programmers is when we have primitive data types then why does there arise a need for the concept of wrapper classes in java. It is because of the additional features being there in the Wrapper class over the primitive data types when it comes to usage. These metho
3 min read