JAVA 中HashMap的几种遍历方式
创建HashMap对象
Map<String, Integer> map = new HashMap<>();
map.put("手表", 1000);
map.put("手机", 4000);
map.put("牙刷", 200);
map.put("耳机",1500);
1.通过遍历map的键的方式,使用键找值进行遍历。
- 现获取Map集合的全部键的Set集合。
- 遍历键的Set集合,然后通过键找到对应的值。
//1.通过遍历key的方式进行遍历,键找值
// map的keySet()返回的是set集合
Set<String> keys = map.keySet();
// 遍历map
for (String key : keys) {
System.out.println(key+" " +map.get(key));
}
//1的简洁写法
for (String s : map.keySet()) {
System.out.println(s+" " +map.get(s));
}
因为hashmap
存储时时无序的,所以遍历出来的顺序和存储顺序不同,如果想有序,可以使用LinkedHashMap
。
2. 通过键值对的方式进行遍历
- 先把Map集合转换成Set集合,Set中每个元素都是键值对实体类型
Map.Entry<String, Integer>
。 - 遍历Set集合,然后提取键以及提取值。
// 2.键值对的方式进行遍历
// 我们可以通过获得map中的entry,来对map进行遍历, 调用map.entrySet(),会将key和value封装成Map.Entry对象
Set<Map.Entry<String, Integer>> entry = map.entrySet();
for (Map.Entry<String, Integer> sentry : entry) {
System.out.println(sentry.getKey() + " " + sentry.getValue());
}
// 2的简洁写法
for (Map.Entry<String, Integer> stringIntegerEntry : map.entrySet()) {
System.out.println(stringIntegerEntry.getKey() +" " + stringIntegerEntry.getValue());
}
3. 与2方法类似,但是可以使用迭代器遍历键值对的Set集合。
//3.通过构造Map.Entry<String, Integer>的迭代器,通过迭代器对map.entrySet()进行遍历,不过本质与第二种方法相同,不推荐。
Iterator<Map.Entry<String,Integer>> iter = map.entrySet().iterator();
while(iter.hasNext()){
Map.Entry<String,Integer> temp = iter.next();
System.out.println(temp.getKey() + " " + temp.getValue());
}
4. JDK 8开始的新技术Lambda表达式,提供了一种更简单、更直接的遍历集合的方式,lamda表达式遍历
// 4.JDK 8开始的新技术Lambda表达式,提供了一种更简单、更直接的遍历集合的方式,lamda表达式遍历
map.forEach(new BiConsumer<String, Integer>() {
@Override
public void accept(String s, Integer integer) {
System.out.println(s +" "+ integer);
}
});
// 4的简化写法
map.forEach((k,v)->{
System.out.println(k +" "+ v);
});
另外还可对Map的值进行遍历
//遍历map的value
Collection<Integer> value = map.values();
for (Integer integer : value) {
System.out.println(integer);
}
// 简化写法
for (Integer integer : map.values()) {
System.out.println(integer);
}