Java中遍历Map集合的五种方式,硬核

本文详细介绍了Java中HashMap的五种遍历方式,包括通过Map.entrySet使用iterator、通过Map.keySet、For-Each迭代entries、lambda表达式forEach。推荐使用entrySet遍历Map类集合,以提高代码可读性和效率。
摘要由CSDN通过智能技术生成

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值