今天小編給大家分享一下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循環優劣勢是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注創新互聯行業資訊頻道。
分享標題:java迭代器和for循環優劣勢是什么
文章URL:http://vcdvsql.cn/article28/iihdjp.html
成都網站建設公司_創新互聯,為您提供虛擬主機、網站營銷、搜索引擎優化、定制開發、企業建站、域名注冊
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯