但是增强for循环有些缺点,例如不能在增强循环里动态的删除集合内容。不能获取下标等。
2.ArrayList由于使用数组实现,因此下标明确,最好使用普通循环。
3.而对于LinkedList 由于获取一个元素,要从头开始向后找,因此建议使用增强for循环,也就是iterator。
下面的例子可以证明
package com.recyle;
import java.util.LinkedList;
import java.util.List;
public class Recyle {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
List<Integer> list = new LinkedList<Integer>();
for (int i = 0; i < 5000; i++) {
list.add(77);
}
int resule = 0;
long time = System.currentTimeMillis();
for (int i = 0; i < list.size(); i++) {
resule = list.get(i);
}
System.out.println("普通循环使用了" + (System.currentTimeMillis() - time)
+ "毫秒");
time = System.currentTimeMillis();
for (int lists : list) {
}
System.out.println("增强for循环使用了" + (System.currentTimeMillis() - time)
+ "毫秒");
}
}
使用LinkedList运行结果如下
把LinkedList改为ArrayList,运行结果如下