遍历HashMap,在代码中很常见,那么,你更倾向那种呢?
下面我将介绍五种写法,看看孰优孰劣:
新建Map并填充
Map<String, String> map = new HashMap<String, String>();
map.put("1", "value1");
map.put("2", "value2");
map.put("3", "value3");
1>lamda直接遍历-----简单,内部实现还是entrySet(推荐)
map.forEach((k,v) -> System.out.println("key:"+k+" "+"value:"+v));
2>entrySet结合iterator-----优秀(推荐)
Iterator<Map.Entry<String, String>> iterator = map.entrySet().iterator();
while (iterator.hasNext()) {
Map.Entry<String, String> entry = iterator.next();
System.out.println("key:"+entry.getKey()+" "+"value:"+entry.getValue());
// //必须要用itetator.next()获得迭代器,之后才能获取map中的数据,下面这种直接遍历取值会报错
// System.out.println("key:"+iterator.next().getKey()+" "+"value:"+iterator.next().getValue());
}
3>entrySet遍历-----简单,算比较常用(推荐)
for(Map.Entry<String,String> entry:map.entrySet()) {
System.out.println("key:"+entry.getKey()+" "+"value:"+entry.getValue());
}
4>keySet遍历-----简单,但是二次取值(不推荐)
for(String key:map.keySet()) {
System.out.println("key:"+key+" "+"value:"+map.get(key));
}
5>values遍历-----只能遍历value(不推荐)
for(String value:map.values()) {
System.out.println("value:"+value);
}