使用例子:
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