Java fori foreach 【vaynexiao】

import java.util.ArrayList;
import java.util.LinkedList;

public class Test01 {
    public static void main(String[] args) {
        ArrayList<Integer> arrayList = new ArrayList<>();
        LinkedList<Integer> linkedList = new LinkedList<>();

        for (int i=0;i<100000;i++){
            linkedList.add(i);
            arrayList.add(i);
        }

        long one = System.nanoTime();
        for(int i=0;i<arrayList.size();i++){
            Integer integer = arrayList.get(i);
        }
        long two = System.nanoTime();
        System.out.println(two-one+":以fori的方式循环arraylist");

        long one1 = System.nanoTime();
        for(Integer i: arrayList){
            Integer integer = arrayList.get(i);
        }
        long two1 = System.nanoTime();
        System.out.println(two1-one1+":以foreach的方式循环arraylist");

        long three = System.nanoTime();
        for(int i=0;i<linkedList.size();i++){
            Integer integer = linkedList.get(i);
        }
        long four = System.nanoTime();
        System.out.println(four-three+":以fori的方式循环linkedList");

        long three1 = System.nanoTime();
        for(Integer i:linkedList){
            Integer integer = linkedList.get(i);
        }
        long four1 = System.nanoTime();
        System.out.println(four1-three1+":以foreach的方式循环linkedList");
        /** * 701300:以fori的方式循环arraylist * 1815300:以foreach的方式循环arraylist * 50713100:以fori的方式循环linkedList * 46270000:以foreach的方式循环linkedList * * 在循环以array为底层实现的ArrayList的时候,fori的效率大概是foreach的3-4倍左右。 * 在循环以连表为底层实现的LinkedList的时候,foreach的效率比fori稍快。 * 对于不一样的底层集合,能够有根据的选择适合的循环方式 */
    }
}