Java中遍历Map集合的5种方式总结

网友投稿 278 2022-11-04


Java中遍历Map集合的5种方式总结

方式一 通过Map.keySet使用iterator遍历

@Test

public void testHashMap1() {

Map map = new HashMap<>();

map.put(001, "java");

map.put(002, "数据库");

map.put(003, "vue");

System.out.println(map);

// 通过Map.keySet使用iterator遍历key,然后通过key得到对应的value值

Iterator iterator = map.keySet().iterator();

while (iterator.hasNext()) {

Integer key = iterator.next();

String value = map.get(key);

System.out.println("key = " + key + ", value = " + value);

}

}

结果:

{1=Java, 2=数据库, 3=Vue}

key = 1, value = Java

key = 2, value = 数据库

key = 3, value = Vue

方式二 通过Map.entrySet使用iterator遍历

@Test

public void testHashMap2() {

Map 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> entries = map.entrySet().iterator();

while (entries.hasNext()) {

Map.Entry entry = entries.next();

System.out.println(entry);

}

}

结果:

{1=Java, 2=数据库, 3=Vue}

1=Java

2=数据库

3=Vue

方式三 通过Map.keySet遍历

@Test

public void testHashMap3() {

Map 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, value = Java

key = 2, value = 数据库

key = 3, value = Vue

方式四 通过For-Each迭代entries,使用Map.entrySet遍历

@Test

public void testHashMap4() {

Map 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 entry : map.entrySet()) {

System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());

}

}

{1=Java, 2=数据库, 3=Vue}

key = 1, value = Java

key = 2, value = 数据库

khttp://ey = 3, value = Vue

方式五 使用lambda表达式forEach遍历

@Test

public void testHashMap5() {

Map 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 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 方式进行遍历。

keySet 其实是遍历了 2 次,第一次是转为 Iterator 对象,第二次是从 hashMap 中取出 key 所对应的 value值。而 entrySet 只是遍历了一次,就把 key 和 value 都放到了 entry 中,效率更高。

values()返回的是 V 值集合,是一个 list 集合对象;keySet()返回的是 K 值集合,是一个 SetBZvfZ 集合对象;entrySet()返回的是 K-V 值组合集合。

如果是 JDK8,推荐使用Map.forEach 方法(文章中的第五种方式)。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:社保网上查询API(社保网上查询初始密码是多少)
下一篇:2020之后IT技术的应用思考
相关文章

 发表评论

暂时没有评论,来抢沙发吧~