HashMap遍历:entrySet和keySet的比较

使用例子:

entrySet():

Map map = new HashMap(); 
Iterator iter = map.entrySet().iterator(); 
while (iter.hasNext()) { 
    Map.Entry entry = (Map.Entry) iter.next(); 
    Object key = entry.getKey(); 
    Object val = entry.getValue(); 
}

keySet():

Map map = new HashMap(); 
Iterator iter = map.keySet().iterator(); 
while (iter.hasNext()) { 
    Object key = iter.next(); 
    Object val = map.get(key); 
}

两者的区别是:

1、使用entrySet则必须将map对象转换为Map.Entry,keySet则不需要

2、keySet其实是遍历了2次,一次是转为iterator,一次就从hashmap中取出key所对于的value。而entryset只是遍历了第一次,他把key和value都放到了entry中。因此entrySet在速度上比keySet快,而且快很多


因此当需要遍历HashMap时,推荐使用entrySet!


或许有人会说,不是还可以直接这样遍历嘛?

Map map = new HashMap();
for(Entry entry : map.entrySet()) {
     Object key = entry.getKey(); 
     Object val = entry.getValue();
}


事实上呢,foreach最终的实现其实还是Iterator,关于for/foreach/Iterator三者的区别可以参考:

http://blog.csdn.net/nazir2513/article/details/51168345





转载于:https://my.oschina.net/u/2250363/blog/666843

你可能感兴趣的:(HashMap遍历:entrySet和keySet的比较)