增强for循环用法
1.首先增强for循环和iterator遍历的效果是一样的,也就说增强for循环的内部也就是调用iteratoer实现的,但是增强for循环有些缺点,例如不能在增强循环里动态的删除集合内容、不能获取下标等。
2.ArrayList由于使用数组实现,因此下标明确,最好使用普通循环。
3.而对于LinkedList 由于获取一个元素,要从头开始向后找,因此建议使用增强for循环,也就是iterator。
4.当遍历集合或数组时,如果需要访问集合或数组的下标,那么最好使用旧式的来实现遍历或循环,而不要使用增强的for循环,因为它丢失了下标信息。
下面的例子可以证明:
- package com.ljq.test;
- import java.util.ArrayList;
- import java.util.LinkedList;
- import java.util.List;
- /**
- * 增强for循环用法
- *
- * @author jiqinlin
- *
- */
- public class ForTest {
- public static void main(String[] args) {
- //List<Integer> list = new ArrayList<Integer>();
- List<Integer> list = new LinkedList<Integer>();
- for (int i = 0; i < 50000; i++) {
- list.add(11);
- }
- int resutl = 0;
- long start = System.currentTimeMillis();
- for (int i = 0; i < list.size(); i++) {
- resutl = list.get(i);
- }
- System.out.println("普通循环使用了"+ (System.currentTimeMillis() - start)+"毫秒");
- start = System.currentTimeMillis();
- for (int c2 : list) {
- }
- System.out.println("增强for循环使用了"+ (System.currentTimeMillis() - start)+"毫秒");
- }
- }
把ArrayList改为LinkedList,我这里内存溢出了,运行结果如下:
于是list改成50000,运行结果如下:
遍历LinkedList时,增强for循环的速速明显比普通循环快很多倍。
所以在使用的时候适当选择就好了。
本文转载自:http://www.cnblogs.com/linjiqin/archive/2011/02/10/1950929.html