Is declaring a variable inside a loop is good or declaring on the fly optimal in Java.Also is there any performance cost involved while declaring inside the loop?
eg.
Option 1: Outside the Loop
List list = new ArrayList();
int value;
//populate list
for(int i = 0 ; i < list.size(); i++) {
value = list.get(i);
System.out.println(“value is ”+ value);
}
Option 2: Inside the Loop
List list = new ArrayList();
//populate list
for(int i = 0; i < list.size(); i++) {
int value = list.get(i);
System.out.println(“value is ”+ value);
}
In Clean Code, Robert C. Martin advises Java coders to declare variables as close as possible to where they are to be used. Variables should not have greater scope than necessary. Having the declaration of a variable close to where it’s used helps give the reader type and initialization information. Don’t concern yourself too much with performance because the JVM is pretty good at optimizing these things. Instead focus on readability.
BTW: If you’re using Java 5 or greater, you can significantly trim up your code example using the following new-for-Java-5 features:
I’ve refactored your example to use the aforementioned new features.