Map遍历的两种方式:keySet()、entrySet()

先上例子

Map<String, Object> map = new HashMap<String, Object>();
        map.put("key1", "value1");
        map.put("key2", "value2");
        map.put("key3", "value3");
        map.put("key4", "value4");
        
        Set<String> set = map.keySet();
        Iterator<String> iterator = set.iterator();
        while(iterator.hasNext()) {
            String key = iterator.next();
            System.out.println(key);
            System.out.println(map.get(key));
        }
        
        Set<Entry<String, Object>> set1 = map.entrySet();
        for(Entry<String, Object> entry : set1) {
            System.out.println(entry.getKey());
            System.out.println(entry.getValue());
        }

两者最主要的区别在于:keySet()只能获得key,需要获得值的时候需要map.get(key),其源码最终也是转为Entry进行获取key的值.

故entrySet省略了获取value的单独操作.

keySet() 会生成KeyIterator迭代器,其next方法只返回其key值 :

private class KeyIterator extends HashIterator<K> {   
       public K next() {   
           return nextEntry().getKey();   
       }   
   }

entrySet() 会生成EntryIterator 迭代器,其next方法返回一个Entry对象的一个实例,其中包含key和value :

private class EntryIterator extends HashIterator<Map.Entry<K,V>> {   
       public Map.Entry<K,V> next() {   
           return nextEntry();   
       }   
}

猜你喜欢

转载自my.oschina.net/u/2462104/blog/1807738