java中的List和HashMap的區(qū)別

最近在面試中經(jīng)常會被問起關(guān)于集合之間的區(qū)別今天就好好查閱了一下資料;

1.首先是數(shù)據(jù)結(jié)構(gòu)的區(qū)別:

ArrayList 底層數(shù)據(jù)結(jié)構(gòu)是數(shù)組;
hashmap 的底層數(shù)據(jù)結(jié)構(gòu)是數(shù)組+鏈表;java8以后是數(shù)組+鏈表(當(dāng)數(shù)組長度大于8時(shí)鏈表會變成紅黑樹);

2.數(shù)據(jù)存儲方式的區(qū)別:

ArrayList 是線性列表存儲,長度可以動態(tài)改變;
hashmap 是健-值對存儲,長度可以動態(tài)改變;

3.查詢速度

ArrayList 查詢最快,O(1)

4.迭代方式

ArrayList可以通過for foreach Iterator 進(jìn)行迭代;
例如

 Iterator<News> iter = list.iterator();
     while (iter.hasNext()) {
            News s = (News) iter.next();
            System.out.println(s.getId()+"  "+s.getTitle()+"  "+s.getAuthor());
    }

hashmap 遍歷方式有:迭代器(Iterator)方式遍歷/For Each 方式遍歷/Lambda 表達(dá)式遍歷(JDK 1.8+)Streams API 遍歷(JDK 1.8+);基于這種迭代方式又有七種實(shí)現(xiàn)方式;
1.使用迭代器(Iterator)EntrySet 的方式進(jìn)行遍歷;

Iterator<Map.Entry<Integer, String>> iterator = map.entrySet().iterator();
        while (iterator.hasNext()) {
            Map.Entry<Integer, String> entry = iterator.next();
            System.out.println(entry.getKey());
            System.out.println(entry.getValue());
        }

2.使用迭代器(Iterator)KeySet 的方式進(jìn)行遍歷;

Iterator<Integer> iterator = map.keySet().iterator();
        while (iterator.hasNext()) {
            Integer key = iterator.next();
            System.out.println(key);
            System.out.println(map.get(key));
        }

3.使用 For Each EntrySet 的方式進(jìn)行遍歷;

 for (Map.Entry<Integer, String> entry : map.entrySet()) {
            System.out.println(entry.getKey());
            System.out.println(entry.getValue());
        }

4.使用 For Each KeySet 的方式進(jìn)行遍歷;

for (Integer key : map.keySet()) {
            System.out.println(key);
            System.out.println(map.get(key));
        }

5.使用 Lambda 表達(dá)式的方式進(jìn)行遍歷;

map.forEach((key, value) -> {
            System.out.println(key);
            System.out.println(value);
        });

6.使用 Streams API 單線程的方式進(jìn)行遍歷;

map.entrySet().stream().forEach((entry) -> {
            System.out.println(entry.getKey());
            System.out.println(entry.getValue());
        });

7.使用 Streams API 多線程的方式進(jìn)行遍歷。性能最好

map.entrySet().parallelStream().forEach((entry) -> {
            System.out.println(entry.getKey());
            System.out.println(entry.getValue());
        });
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容