直接上例子:java
package com.test.collections.list; import java.util.ArrayList; import java.util.Iterator; /** * * ArrayList测试类 * @author work * */ public class TestArraryList{ private static ArrayList<String> strs = new ArrayList<String>(); /** * 赋值操做 * @param arrays 数组 */ private static void setValue(String[] arrays){ strs.toArray(arrays); } /** * 得到ArrayList的值 */ public static void foreachValue(){ long start = System.currentTimeMillis(); for (String str : strs) { //System.out.println("foreach value : "+ str); } long end = System.currentTimeMillis(); System.out.println("foreachValue 耗时 :" + (end-start)); } /** * 赋值操做 */ private static void setValue(){ for(int i=0; i<10000000; i++){ strs.add("strs"+i); } } private static void iterValue(){ long start = System.currentTimeMillis(); for (Iterator<String> iterator = strs.iterator(); iterator.hasNext();) { String str = (String) iterator.next(); //System.out.println(" iterator value "+ str); } long end = System.currentTimeMillis(); System.out.println(" ArrayList iterValue 耗时 :" + (end-start)); } private static void forValue(){ long start = System.currentTimeMillis(); for (int i = 0; i < strs.size(); i++) { strs.get(i); } long end = System.currentTimeMillis(); System.out.println(" ArrayList forValue 耗时 :" + (end-start)); } public static void main(String[] args){ setValue(); foreachValue(); iterValue(); forValue(); } }
运行结果:数组
ArrayList foreachValue 耗时 :52测试
ArrayList iterValue 耗时 :52指针
ArrayList forValue 耗时 :3code
结果显示foreach是耗时最久的,产生这种状况的缘由是什么呢?接口
ArrayList:List接口大小可变的数组的实现,这是问题的根本缘由,由于是数组,因此直接使用for的时候是最快了,而使用foreach或者iterator的时候都是经过指针来寻找数据,所以会慢一些,而foreach和iterator的效率差很少,foreach稍微慢一点,是由于foreach也是经过最终调用iterator.next()来实现的,所以会比较慢一点!!!
get