@Test
public void testHashMap2() {
Map<Integer, String> map = new HashMap<>();
map.put(001, “Java”);
map.put(002, “数据库”);
map.put(003, “Vue”);
System.out.println(map);
// 通过Map.entrySet使用iterator遍历key和value;注意 Set entrySet():返回所有key-value对构成的Set集合
Iterator<Map.Entry<Integer, String>> entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry<Integer, String> entry = entries.next();
System.out.println(entry);
}
}
结果:
{1=Java, 2=数据库, 3=Vue}
1=Java
2=数据库
3=Vue
方式三 通过Map.keySet遍历
@Test
public void testHashMap3() {
Map<Integer, String> map = new HashMap<>();
map.put(001, “Java”);
map.put(002, “数据库”);
map.put(003, “Vue”);
System.out.println(map);
// 通过Map.keySet遍历key,然后通过key得到对应的value值
for (Integer key : map.keySet()) {
System.out.println("key = " + key + ", value = " + map.get(key));
}
}
结果:
{1=Java, 2=数据库, 3=Vue}
key = 1,
【一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义】
浏览器打开:qq.cn.hn/FTf 免费领取
value = Java
key = 2, value = 数据库
key = 3, value = Vue
方式四 通过For-Each迭代entries,使用Map.entrySet遍历
@Test
public void testHashMap4() {
Map<Integer, String> map = new HashMap<>();
map.put(001, “Java”);
map.put(002, “数据库”);
map.put(003, “Vue”);
System.out.println(map);
// 使用For-Each迭代entries,通过Map.entrySet遍历key和value
for (Map.Entry<Integer, String> entry : map.entrySet()) {
System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
}
}
{1=Java, 2=数据库, 3=Vue}
key = 1, value = Java
key = 2, value = 数据库
key = 3, value = Vue
方式五 使用lambda表达式forEach遍历
@Test
public void testHashMap5() {
Map<Integer, String> map = new HashMap<>();
map.put(001, “Java”);
map.put(002, “数据库”);
map.put(003, “Vue”);
System.out.println(map);
// 使用lambda表达式forEach遍历
map.forEach((k, v) -> System.out.println("key = " + k + ", value = " + v));
}
forEach 源码
default void forEach(BiConsumer<? super K, ? super V> action) {
Objects.requireNonNull(action);
for (Map.Entry<K, V> entry : entrySet()) {
K k;
V v;
try {
k = entry.getKey();
v = entry.getValue();
} catch(IllegalStateException ise) {
// this usually means the entry is no longer in the map.
throw new ConcurrentModificationException(ise);
}
action.accept(k, v);
}
}
从源码可以看到,这种新特性就是在传统的迭代方式上加了一层壳,但是让代码变得更加简单。(开发中推荐使用
)
总结
推荐使用 entrySet 遍历 Map 类集合 KV
(文章中的第四种方式),而不是 keySet 方式进行遍历。