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