java迭代器和for循環優劣詳解
在進行迭代的時候,程序運行的效率也是我們挑選迭代方法的重要原因。目前有三種迭代方法:for循環、迭代器和Foreach。前兩者相信大家都非常熟悉,為了更加直觀分析效率的不同,我們還加入Foreach一起比較。下面我們就三種方法的概念進行理解,然后ArrayList中探索三種方法的效率。
1.概念理解for循環:是支持迭代的一種通用結構,是最有效,最靈活的循環結構
迭代器:是通過集合的iterator()方法得到的,所以我們說它是依賴于集合而存在的
Foreach:通過閱讀源碼我們還發現一個Iterable接口。它包含了一個產生Iterator對象的iterator()方法,而且將Iterator對象被foreach用來在序列中移動。對于任何實現Iterable接口的對象都可以使用。
2.效率實例ArrayList中的效率對比:
List<Integer> integers = Lists.newArrayList(); for(int i=0;i<100000;i++){ integers.add(i); } long start1 = System.currentTimeMillis(); for(int count =0 ;count<10;count++){ for(int i=0;i<integers.size();i++){int j=integers.get(i); } } System.out.println(String.format('for循環100次時間:%s ms',System.currentTimeMillis()-start1)); long start2 = System.currentTimeMillis(); for(int count =0 ;count<10;count++) { for (Integer i : integers) {int j = i; } } System.out.println(String.format('foreach循環100次時間:%s ms',System.currentTimeMillis()-start2)); long start3 = System.currentTimeMillis(); for(int count =0 ;count<10;count++) { Iterator<Integer> iterator = integers.iterator(); while(iterator.hasNext()){int j=iterator.next(); } } System.out.println(String.format('迭代器循環100次時間:%s ms',System.currentTimeMillis()-start3));
結果:
for循環100次時間:15 ms
foreach循環100次時間:25 ms
迭代器循環100次時間:20 ms
知識點擴展:
增強for循環:foreach
在Java 5.0提供了一種新的迭代訪問 Collection和數組的方法,就是foreach循環。使用foreach循環執行遍歷操作不需獲取Collection或數組的長度,也不需要使用索引訪問元素。
到此這篇關于java迭代器和for循環優劣詳解的文章就介紹到這了,更多相關分析java迭代器和for循環優劣內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. AJAX實現省市縣三級聯動效果2. Java基于redis和mysql實現簡單的秒殺(附demo)3. 如何用python識別滑塊驗證碼中的缺口4. IntelliJ IDEA設置編碼格式的方法5. Kotlin + Flow 實現Android 應用初始化任務啟動庫6. SpringBoot+SpringCache實現兩級緩存(Redis+Caffeine)7. php讀取xml中某個元素的內容(PHP5以上才支持)8. IDEA SpringBoot 項目配置Swagger2的詳細教程9. Docker究竟是什么 為什么這么流行 它的優點和缺陷有哪些?10. ASP.NET MVC視圖頁使用jQuery傳遞異步數據的幾種方式詳解
