最近在优化代码时遇到了这个问题:Iterator与增强for循环到底哪个效率高?之前在学习的时候,好像记着老师说过遍历集合(如list)时,使用iterator好像正规一些,因为是专用的,但是运行效率问题确实不曾考虑,今天做了一个实验:对两者进行了简单的比较,得出的结论是:增强for循环运行效率更高一些。但是我不确定这是否会代表全部情况,这里仅仅记录一下,做个参考,后期有新的认识再来补充,欢迎大家批评指正。
public static void main(String[] args) {
test();
} public static void test() { List<Integer> list = new ArrayList<Integer>();
int flag = 100000;
int i=0;
while(i<flag) {
list.add(i);
i++;
} // iterator测试
long start = System.currentTimeMillis();
Iterator<Integer> iterator = list.iterator();
while(iterator.hasNext()) {
System.out.print(iterator.next());
}
long end = System.currentTimeMillis();
System.out.println("iterator本次执行耗费了"+(end-start)+"毫秒"); // 增强for循环测试
long start2 = System.currentTimeMillis();
for(Integer inte : list) {
System.out.print(inte);
}
long end2 = System.currentTimeMillis();
System.out.println("for本次执行耗费了"+(end2-start2)+"毫秒");
}
运行结果为: