java关于for,foreach,iterator循环ArrayList的方式测试

直接上例子: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