Java for循环写法效率

∥☆過路亽.° 提交于 2019-12-09 06:27:30
import java.util.ArrayList;
import java.util.List;

public class Main {

    private static void test(List<Integer> list) {
        long start = 0L;
        long end = 0L;
        // ==============================
        start = System.currentTimeMillis();
        for (Integer i : list) {

        }
        end = System.currentTimeMillis();
        System.out.println(end - start);
        // ==============================
        start = System.currentTimeMillis();
        for (int i=0;i<list.size();i++) {
            Integer j=list.get(i);
        }
        end = System.currentTimeMillis();
        System.out.println(end - start);

        // ==============================
        start = System.currentTimeMillis();
        for (int i=0,k=list.size();i<k;i++) {
            Integer j=list.get(i);
        }
        end = System.currentTimeMillis();
        System.out.println(end - start);
    }

    public static void main(String[] args) {
        List<Integer> list=new ArrayList<>();
        for(int i=0;i<20000000;i++){
            list.add(i);
        }
        test(list);
    }
}

迭代器:85ms(用了Iterator的遍历,Iterator是需要考虑同步的)
下标访问:60ms(ArrayList的效率要比LinkedList的效率要高,因为Array擅长随机访问)
优化的下标访问:59ms

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!