bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

java迭代器和for循環優劣勢是什么

今天小編給大家分享一下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。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網站建設