当前位置:网站首页>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,可以参考:
边栏推荐
猜你喜欢
EA&UML日拱一卒-活动图::StartClassifierBehavior和StartObjectBehavior
Children's programming electronics (graphical programming Scratch secondary level exam parsing (choice) in June 2022
EA&UML日拱一卒-活动图::Variable Actions(续)
搞直播啦,千视超高清4K NDI编解码器8月3日19:00准时开播
【JS面试题】面试官问我:遍历一个数组用 for 和 forEach 哪个更快?
计算机专业面试进阶指南
kubernetes cks strace etcd
力扣 206.反转链表--递归解决
C#线程操作UI控件
Still developing SMS verification code login?Try it (one-click login with your phone number)
随机推荐
即时通讯移动端开发之网络连接优化
为什么 ThreadLocal 可以做到线程隔离?
已解决SyntaxError: invalid character in identifier
基于降噪自编码器与改进卷积神经网络的采煤机健康状态识别
【LeetCode】593. 有效的正方形
有关包装类的一道经典面试题
kubernetes cks strace etcd
TAP 文章系列-10 | 从应用感知能力谈 TAP 的约定服务
全面质量管理理论
数据库mysql的执行顺序(sql语句大全实例教程)
浅谈如何在渗透测试中快速搞定webshell
leetcode linked list topic
Understand the yolov7 network structure
The 10,000-character long article reveals the secrets of Huawei's data governance system!
Violence recursion to dynamic programming 02 (very clever game of CARDS)
你真的会用Console.log吗?
面试官:大量请求 Redis 不存在的数据,从而影响数据库,该如何解决?
3555. 二叉树
关于知识付费的一些思考
手摸手写一个互联网黑话生成器