1. 程式人生 > >Map集合遍歷兩種方式區別和效能

Map集合遍歷兩種方式區別和效能

Map<String,String> map = new HashMap<String,String>();
map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");

Collection<String> collection = map.values();//返回值是個值的Collection集合
System.out.println(collection);
列印結果:
[zhangsan, lisi, wangwu]


Set<K> keySet() //返回值是個只存放key值的Set集合(集合中無序存放的)


Set<Map.Entry<K,V>> entrySet() //返回對映所包含的對映關係的Set集合(一個關係就是一個鍵-值對),就是把(key-value)作為一個整體一對一對地存放到Set集合當中的。



一. keySet()方式。

Map<String,String> map = new HashMap<String,String>();

        map.put("01", "zhangsan");
        map.put("02", "lisi");
        map.put("03", "wangwu");


        Set<String> keySet = map.keySet();//先獲取map集合的所有鍵的Set集合


        Iterator<String> it = keySet.iterator();//有了Set集合,就可以獲取其迭代器。

        while(it.hasNext()){
                String key = it.next();
                String value = map.get(key);//有了鍵可以通過map集合的get方法獲取其對應的值。

                System.out.println("key: "+key+"-->value: "+value);//獲得key和value值
                }


二. entrySet()方式:
Map<String,String> map = new HashMap<String,String>();

map.put("01", "zhangsan");
map.put("02", "lisi");
map.put("03", "wangwu");

//通過entrySet()方法將map集合中的對映關係取出(這個關係就是Map.Entry型別)
Set<Map.Entry<String, String>> entrySet = map.entrySet();

//將關係集合entrySet進行迭代,存放到迭代器中                
Iterator<Map.Entry<String, String>> it2 = entrySet.iterator();

while(it2.hasNext()){
        Map.Entry<String, String> me = it2.next();//獲取Map.Entry關係物件me
        String key2 = me.getKey();//通過關係物件獲取key
        String value2 = me.getValue();//通過關係物件獲取value

        System.out.println("key: "+key2+"-->value: "+value2);
}

雖然使用keyset及entryset來進行遍歷能取得相同的結果
但兩者的遍歷速度是有差別的

keySet():迭代後只能通過get()取value
entrySet():迭代後可以e.getKey(),e.getValue()取key和value。返回的是Entry介面 


說明:keySet()的速度比entrySet()慢了很多,也就是keySet方式遍歷Map的效能不如entrySet效能好