当前位置:网站首页>Map遍历 key-value 的4种方法
Map遍历 key-value 的4种方法
2022-07-29 13:59:00 【肥肥技术宅】
四种方法
先用
keySet()取出所有key值,再取出对应value——增强for循环遍历先用
keySet()取出所有key值,再取出对应value——使用迭代器遍历通过
entrySet来获取key-value——增强for循环遍历通过
entrySet来获取key-value——使用迭代器遍历

Map是java中的接口,Map.Entry是Map的一个内部接口。Map提供了一些常用方法,如keySet()、entrySet()等方法,keySet()方法返回值是Map中key值的Set集合;entrySet()的返回值也是返回一个Set集合,此集合的类型为Map.Entry<K, V>。
Map.Entry是Map声明的一个内部接口,此接口为泛型,定义为Entry<K,V>。它表示Map中的一个实体(一个key-value对)。接口中有getKey(),getValue方法。
1、构造HashMap,给hashMap添加元素
HashMap hashMap = new HashMap();
hashMap.put("三国演义","罗贯中");
hashMap.put("水浒传","施耐庵");
hashMap.put("西游记","吴承恩");
hashMap.put("红楼梦","曹雪芹");
2、 方法一:先用keySet()取出所有key值,再取出对应value——使用迭代器遍历
2.1 代码
/*1、先用keySet()取出所有key值,再取出对应value——增强for循环遍历*/
System.out.println("====1、先用keySet()取出所有key值,再取出对应value——增强for循环遍历====");
Set keyset = hashMap.keySet();
for(Object key:keyset){
System.out.println(key+"-"+hashMap.get(key));
}
2.2 运行结果

3、 方法二:先取出所有的key,再通过key取出对应的value——使用迭代器遍历
3.1 代码
/*2、先用keySet()取出所有key值,再取出对应value——使用迭代器遍历*/
System.out.println("====2、先用keySet()取出所有key值,再取出对应value——使用迭代器遍历====");
Iterator iterator = keyset.iterator();
while(iterator.hasNext()){
Object key = iterator.next();
System.out.println(key+"-"+hashMap.get(key));
}
3.2 运行结果

4、 方法三:通过entrySet()获得key-value值——增强for循环遍历
4.1 代码
/*3、通过entrySet()获得key-value值——增强for循环遍历*/
System.out.println("====3、通过entrySet()获得key-value值——增强for循环遍历====");
Set set = hashMap.entrySet();
for(Object key:set){
Map.Entry entry = (Map.Entry) key;
System.out.println(entry.getKey()+"-"+entry.getValue());
}
4.2 运行结果

5、 方法四:通过entrySet()获得key-value值——使用迭代器遍历
5.1 代码
/*4、通过entrySet()获得key-value值——使用迭代器遍历*/
System.out.println("====4、通过entrySet()获得key-value值——使用迭代器遍历====");
Set set1 = hashMap.entrySet();
Iterator iterator1 = set1.iterator();
while(iterator1.hasNext()){
Object itset = iterator1.next();
Map.Entry entry = (Map.Entry) itset;
System.out.println(entry.getKey()+"-"+entry.getValue());
}
5.2 运行结果

6、完整代码
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class MapTraverse {
public static void main(String[] args){
HashMap hashMap = new HashMap();
hashMap.put("三国演义","罗贯中");
hashMap.put("水浒传","施耐庵");
hashMap.put("西游记","吴承恩");
hashMap.put("红楼梦","曹雪芹");
/*1、先用keySet()取出所有key值,再取出对应value——增强for循环遍历*/
System.out.println("====1、先用keySet()取出所有key值,再取出对应value——增强for循环遍历====");
Set keyset = hashMap.keySet();
for(Object key:keyset){
System.out.println(key+"-"+hashMap.get(key));
}
/*2、先用keySet()取出所有key值,再取出对应value——使用迭代器遍历*/
System.out.println("====2、先用keySet()取出所有key值,再取出对应value——使用迭代器遍历====");
Iterator iterator = keyset.iterator();
while(iterator.hasNext()){
Object key = iterator.next();
System.out.println(key+"-"+hashMap.get(key));
}
/*3、通过entrySet()获得key-value值——增强for循环遍历*/
System.out.println("====3、通过entrySet()获得key-value值——增强for循环遍历====");
Set set = hashMap.entrySet();
for(Object key:set){
Map.Entry entry = (Map.Entry) key;
System.out.println(entry.getKey()+"-"+entry.getValue());
}
/*4、通过entrySet()获得key-value值——使用迭代器遍历*/
System.out.println("====4、通过entrySet()获得key-value值——使用迭代器遍历====");
Set set1 = hashMap.entrySet();
Iterator iterator1 = set1.iterator();
while(iterator1.hasNext()){
Object itset = iterator1.next();
Map.Entry entry = (Map.Entry) itset;
System.out.println(entry.getKey()+"-"+entry.getValue());
}
}
}
7、应用举例
7.1 问题描述
使用HashMap添加3个员工对象,要求
键:员工id
值:员工对象 并遍历显示工资>18000的员工(遍历方式最少两种)员工类:姓名、工资、员工id
7.2 代码
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
/*使用HashMap添加3个员工对象,要求
键:员工id
值:员工对象
并遍历显示工资>18000的员工(遍历方式最少两种)员工类:姓名、工资、员工id
*/
public class MapExercise {
public static void main(String[] args) {
HashMap hashMap = new HashMap();
hashMap.put(1, new employee("Tom", 20000.0, 1));
hashMap.put(2, new employee("Jack", 10000.0, 2));
hashMap.put(3, new employee("Bob", 30000.0, 3));
hashMap.put(4, new employee("Marry", 17000.0, 4));
/*1、通过keySet()获取所有key值,再得到对应的value值——增强for循环遍历*/
System.out.println("====1、通过keySet()获取所有key值,再得到对应的value值——增强for循环遍历");
Set keyset = hashMap.keySet();
for (Object key : keyset) {
employee m = (employee) hashMap.get(key);
if (m.getSalary() > 18000) {
System.out.println(m);
}
}
/*2、通过entrySet()获取key-value值——使用迭代器遍历*/
System.out.println("====2、通过entrySet()获取key-value值——使用迭代器遍历====");
Set set = hashMap.entrySet();
Iterator iterator = set.iterator();
while (iterator.hasNext()) {
Object itset = iterator.next();
Map.Entry entry = (Map.Entry) itset;
employee m = (employee) entry.getValue();
if (m.getSalary() > 18000) {
System.out.println(m);
}
}
}
}
class employee{
private String name;
private Double salary;
private int id;
public employee(String name, Double salary, int id) {
this.name = name;
this.salary = salary;
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Double getSalary() {
return salary;
}
public void setSalary(Double salary) {
this.salary = salary;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
@Override
public String toString() {
return "employee{" +
"name='" + name + '\'' +
", salary=" + salary +
", id=" + id +
'}';
}
}
7.3 运行结果

以上是基础的Map遍历方法,Java8简化了很多操作,效率上基本无差,关于Java8新方法遍历Map,可以参考:

边栏推荐
猜你喜欢

中国互联网科技企业群狼围攻,谷歌终于遭受重挫导致利润大跌,它为推动鸿蒙的发展而后悔...

Alibaba CTO Cheng Li: open source is the source of basic software!

日志打印不规范,被CTO骂了一顿~

Offensive EA&UML day arch - activity diagram: : Variable Actions (continue)

已解决SyntaxError: invalid character in identifier

84.(cesium之家)cesium模型在地形上运动

工作效率-十五分钟让你快速学习Markdown语法到精通排版实践备忘

C#线程操作UI控件

2022年七夕情人节有什么值得推荐的礼物选择?实用且高级礼物推荐

Vscode builds ESP32-C3 development environment
随机推荐
C#实现线程管理类
浅谈如何在渗透测试中快速搞定webshell
AI全流程开发难题破解之钥
九种方式,教你读取 resources 目录下的文件路径
唯物辩证法-矛盾论(普遍性+特殊性+斗争性+同一性)
How to return all prime factors of a number?
Why do strings use the final keyword
【10点公开课】:快手GPU/FPGA/ASIC异构平台的应用探索
C#线程操作UI控件
Vscode搭建ESP32-C3开发环境
[10:00 Open Class]: Application Exploration of Kuaishou GPU/FPGA/ASIC Heterogeneous Platform
StarRocks 2.3 新版本特性介绍
【论文阅读】Anomaly Detection in Video via Self-Supervised and Multi-Task Learning
EA&UML日拱一卒-活动图::CallOperationAction(续)
The new technical director, who is in the form of a isXxx Boolean type definition, tomorrow need not come!
苹果官方降价的原因找到了,它也面临销量下滑乃至出现库存问题
EA&UML日拱一卒-活动图::Variable Actions(续)
The Advanced Guide to the Computer Professional Interview
上线前配置
全面质量管理理论