您好,登錄后才能下訂單哦!
今天小編給大家分享一下java迭代器和for循環優劣勢是什么的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
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
ArrayList下三者效率差不多,for循環最優,因為ArrayList通過數組來實現,數組通過索引來定位的時間復雜度是O(1),1次就能定位到,所以效率非常高。
總結:for循環便于訪問順序存儲的記錄,而foreach和迭代器便于訪問鏈接存儲。
以上就是“java迭代器和for循環優劣勢是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。