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

相關文章
相關標籤/搜索