Java遍历Map集合,获取key、value等方式

文章介绍了Java中遍历Map的多种方式,包括通过keySet、values、entrySet以及Lambda表达式进行遍历,并强调了在遍历过程中修改集合的注意事项,推荐使用不同方法处理不同需求,如仅获取key或value、同时获取key和value以及在遍历中删除元素的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先构建一个Map集合:

 Map<String, Integer> buy=new HashMap<>();
        buy.put("苹果手机", 2);//添加键值对
        buy.put("智能手表", 1);
        buy.put("java书", 1);
        buy.put("c语言书", 1);
        buy.put("西瓜", 2);

打印集合:
在这里插入图片描述

一、只需要获取key或者value

1、获取key:

  for (String key : buy.keySet()) {
            System.out.println(key);
        }

结果:
在这里插入图片描述

2、获取value:

 for (Integer value :buy.values()) {
            System.out.println(value);
        }

结果:
在这里插入图片描述

二、同时获取key和value:

1、通过 keySet 的 get(key) 获取值

 for (String key : buy.keySet()) {
   System.out.println(key + ":" + buy.get(key));
      }

结果:
在这里插入图片描述
2、通过 entrySet 遍历

  for (Map.Entry<String, Integer> entry : buy.entrySet()) {
 System.out.println(entry.getKey() + ":" + entry.getValue());
        }

在这里插入图片描述
3、通过 Lambda 表达式遍历

 buy.forEach((key,value)->{
           System.out.println("key:"+key+"value"+value);
        });

结果:
在这里插入图片描述
4、通过迭代器 Iterator 遍历

上面的几种遍历方法都用了增强型 for 循环 —— foreach, 这是 JDK 5 开始才有的特性
foreach 的操作虽然看起来很简洁, 但有一个劣势: 遍历 Map 时, 如果改变其大小, 就会抛出并发修改异常. 但如果在遍历时只需要删除 Map 中的元素, 那就可以用 Iterator 的 remove() 方法删除元素:
,这里例子是删除key为西瓜的元素:

Iterator<Map.Entry<String, Integer>> it = buy.entrySet().iterator();
        while (it.hasNext()) {
            Map.Entry<String, Integer> entry = it.next();
            if (entry.getKey().equals("西瓜")) {
                it.remove();
            }
        }
        System.out.println(buy);

结果:
在这里插入图片描述
总结:
(1) 如果只获取 key 或者 value, 推荐使用 keySet() 或 values() 方法;
(2) 如果需要同时获取 key 和value, 推荐使用 entrySet;
(3) 如果需要在遍历过程中删除元素, 推荐使用 Iterator;
(4) 如果需要在遍历过程中添加元素, 可以新建一个临时 Map 存放新增的元素, 遍历结束后, 再把临时 Map 添加到原 Map 中.

参考链接:Java 遍历 Map 的 5 种方式

<think>好的,用户想了解如何在Java遍历Map获取KeyValue的方法。首先,我需要回忆用户提供的引用内容。引用[1]提到使用entrySet()方法,引用[2]展示了通过keySet()遍历然后获取value,引用[3]则讨论了不同遍历方式的关系。用户之前的问题是关于遍历目录查找JSON文件,现在转向Map遍历,需要确保回答准确且涵盖多种方法。接下来,我需要整理常见的Map遍历方法。根据引用,entrySet()和keySet()是两种基本方式。此外,还有Java8的forEach方法、迭代器方式,以及遍历values()的方法。不过用户主要关注的是同时获取keyvalue,所以values()可能不太相关,但可以作为补充提到。 需要检查每种方法的代码示例是否正确。比如entrySet()的循环是否正确使用Map.Entry,keySet()是否通过get方法获取value。还要注意效率问题,比如entrySet()通常比keySet()更高效,尤其是在大的Map中,因为直接获取entry避免了多次调用get(key)。 另外,用户提到系统级指令,比如数学公式的格式,但当前问题可能不涉及数学内容,所以需要确认是否有必要加入。不过用户的问题主要是代码示例,可能不需要数学公式,但需要确保引用标记正确,比如在提到entrySet()时添加[^1]。 还需要考虑用户可能的深层需求,比如性能比较、不同方法的适用场景,或者是否推荐某种方法。例如,Java8的forEach更简洁,适合函数式编程风格,而迭代器可能在需要删除元素时使用。此外,多线程环境下的遍历是否需要同步处理?最后,生成相关问题时要围绕Map遍历的扩展,比如性能差异、异常处理、并发遍历等。确保问题有针对性,帮助用户进一步学习。</think>### Java遍历Map获取KeyValue的5种方法 #### 方法1:使用entrySet()遍历(推荐) ```java Map<String, Integer> map = new HashMap<>(); map.put("A", 1); map.put("B", 2); for (Map.Entry<String, Integer> entry : map.entrySet()) { String key = entry.getKey(); Integer value = entry.getValue(); System.out.println("Key: " + key + ", Value: " + value); } ``` **特点**:直接获取键值对对象,时间复杂度$O(1)$访问值[^1] #### 方法2:通过keySet()遍历 ```java for (String key : map.keySet()) { Integer value = map.get(key); // 需要二次查询 System.out.println("Key: " + key + ", Value: " + value); } ``` **注意**:当值为null时可能产生歧义,时间复杂度$O(1)*n$[^2] #### 方法3:使用迭代器遍历 ```java Iterator<Map.Entry<String, Integer>> it = map.entrySet().iterator(); while (it.hasNext()) { Map.Entry<String, Integer> entry = it.next(); System.out.println("Key: "+entry.getKey()+", Value: "+entry.getValue()); } ``` **适用场景**:需要在遍历时删除元素的情况(通过`it.remove()`) #### 方法4:Java 8的forEach方法 ```java map.forEach((key, value) -> System.out.println("Key: " + key + ", Value: " + value) ); ``` **特点**:Lambda表达式实现函数式编程,代码最简洁 #### 方法5:单独遍历values() ```java for (Integer value : map.values()) { System.out.println("Value: " + value); } ``` **适用场景**:仅需要值的集合时使用(不获取键) --- ### 性能比较 遍历方式 | 时间复杂度 | 空间复杂度 | 线程安全 ---|---|---|--- entrySet | $O(n)$ | $O(1)$ | ❌ keySet | $O(n)$ | $O(1)$ | ❌ Iterator | $O(n)$ | $O(1)$ | ❌ --- ### 方法选择建议 1. 需要键值对时优先使用`entrySet()`(效率最高)[^1] 2. 仅需要键时使用`keySet()`,仅需要值时用`values()` 3. 需要修改Map时使用迭代器方式 4. Java 8+推荐使用`forEach`写法(代码简洁) --- ### 相关问题 1. 如何解决遍历Map时的并发修改异常? 2. 为什么entrySet遍历keySet遍历更高效? 3. 遍历TreeMap时如何保证有序性? 4. Java 8的forEach方法底层实现原理是什么? 5. 如何实现Map的线程安全遍历
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值