5

I have one list:

List<Object> myList = new ArrayList<Object>();

To get from this list there are two methods:

1.

for(Object obj : myList )
{
    // some code
}

2.

Iterator<Object> objIt = myList.iterator();
while(obj.hasNext()) {
    Object obj = (Object)objIt.next();
    // some code
}

My question is which one is memory efficient and iterates fast?

3

6 Answers 6

12

They do the same thing - the enhanced for loop is just syntactic sugar for the longhand version (for iterables; for arrays it's slightly different). Unless you need the iterator explicitly (e.g. to call remove()) I'd use the first version.

See section 14.14.2 of the Java Language Specification for more details of the exact transformation performed by the compiler.

Sign up to request clarification or add additional context in comments.

2 Comments

I was about to give the similar answer. (Except the section 14... part.) +1 for speed.
The Iterable interface (docs.oracle.com/javase/7/docs/api/java/lang/Iterable.html) says that is designed for the enhanced loop. Just wanted to point out the reference that they are exactly the same.
5

Using an Iterator provides much safer access to the List from outside the defining class as you cannot accidentally override the entire List for example. You can only ever access one element at a time: the top one.

So the guideline we use is to only use the for each approach inside the defining class and whenever the List needs to be accessed from the outside an iterator has to be used. This also enforces the concept of keeping the logic of how to modify a member inside the class that contains it. All complex operations that are needed outside have to be implemented in public methods inside that class.

Comments

2

Iterator : It gives you the result when needed and don't gets all the result in-memory

Comments

2

The first one is what you call an "enhanced for loop" which was introduced in JDK 1.5+

It is more convenient way of iterating through a list. Also, you do not need to do explicit castings if you are using that.

From the performance perspective, I don't think there isn't much difference between the two.

Comments

1

Enhanced for loop used iterator only inside it. So both are same.

Comments

1

First one is more clear, but if you want to remove elements while visiting the list your only choice is an iterator.

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.