小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Alibaba開(kāi)發(fā)手冊(cè):集合遍歷的幾種方式

 印度阿三17 2021-02-13

【推薦】集合初始化時(shí),指定集合初始值大小。

  說(shuō)明:HashMap 使用 HashMap(int initialCapacity) 初始化, 正例:initialCapacity = (需要存儲(chǔ)的元素個(gè)數(shù) / 負(fù)載因子) 1。注意負(fù)載因子(即 loader factor)默認(rèn)為 0.75,如果暫時(shí)無(wú)法確定初始值大小,請(qǐng)?jiān)O(shè)置為 16(即默認(rèn)值)。

    反例:HashMap 需要放置 1024 個(gè)元素,由于沒(méi)有設(shè)置容量初始大小,隨著元素不斷增加,容 量 7 次被迫擴(kuò)大,resize 需要重建 hash 表,嚴(yán)重影響性能。

【推薦】使用 entrySet 遍歷 Map 類集合 KV,而不是 keySet 方式進(jìn)行遍歷。

  說(shuō)明:keySet 其實(shí)是遍歷了 2 次,一次是轉(zhuǎn)為 Iterator 對(duì)象,另一次是從 hashMap 中取出 key 所對(duì)應(yīng)的 value。而 entrySet 只是遍歷了一次就把 key 和 value 都放到了 entry 中,效 率更高。

  如果是 JDK8,使用 Map.foreach 方法。

  正例:values()返回的是 V 值集合,是一個(gè) list 集合對(duì)象;keySet()返回的是 K 值集合,是 一個(gè) Set 集合對(duì)象;

    entrySet()返回的是 K-V 值組合集合。

【參考】利用 Set 元素唯一的特性,可以快速對(duì)一個(gè)集合進(jìn)行去重操作,避免使用 List 的 contains 方法進(jìn)行遍歷、對(duì)比、去重操作。

【推薦】高度注意 Map 類集合 K/V 能不能存儲(chǔ) null 值的情況:

  如下表格:

  反例: 由于 HashMap 的干擾,很多人認(rèn)為 ConcurrentHashMap 是可以置入 null 值,而事實(shí)上, 存儲(chǔ) null 值時(shí)會(huì)拋出 NPE 異常。


public static void main(String[] args) {
        Map<String, String> map = new HashMap<>(16);
        map.put("101", "張三");
        map.put("102", "李四");
        map.put("103", "王五");

        /*遍歷map集合的第一種方式:通過(guò)key獲取value*/
        System.out.println("========通過(guò)key獲取value============");
        // 獲取所有的key
        Set<String> keySet = map.keySet();
        Iterator<String> iterator = keySet.iterator();
        while (iterator.hasNext()) {
            String key = iterator.next();
            // 通過(guò)key獲取value
            String value = map.get(key);
            System.out.println(key   ":"   value);
        }

        System.out.println("========獲取所有的value============");
        Collection<String> values = map.values();
        Iterator<String> iterator1 = values.iterator();
        while (iterator1.hasNext()) {
            System.out.println(iterator1.next());
        }


        System.out.println("=======JDK8的迭代方式=============");
        map.forEach((key, value) -> {
            System.out.println(key   ":"   value);
        });

        System.out.println("=======entrySet比keySet更高效=============");
        Set<Map.Entry<String, String>> entries = map.entrySet();
        Iterator<Map.Entry<String, String>> iterator2 = entries.iterator();
        while (iterator2.hasNext()) {
            System.out.println(iterator2.next());
        }
    }

結(jié)果:

========通過(guò)key獲取value============
101:張三
102:李四
103:王五
========獲取所有的value============
張三
李四
王五
=======JDK8的迭代方式=============
101:張三
102:李四
103:王五
=======entrySet比keySet更高效=============
101=張三
102=李四
103=王五
來(lái)源:https://www./content-4-856201.html

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多