您的位置:首页 > 其它

HashMap遍历:entrySet和keySet的比较

2015-06-02 16:19 357 查看
使用例子:

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三者的区别可以参考:
/article/11272288.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: