Java基础知识之Map的使用

一、Map介绍

Map是用于保存具有映射关系的数据集合,它具有双列存储的特点,即一次必须添加两个元素,即一组键值对==><Key,Value>,其中Key的值不可重复(当Key的值重复的时候,后面插入的对象会将之前插入的具有相同的Key值的对象覆盖掉),Value的值可重复。

其中<Key,Value>键值对在Java语言中又被称之为Entry/entry,Map.Entry就相当于Student.name,若name的数据类型为String,则Student.name的数据类型为String,同理若<key,value>中key的数据类型为Integer,value的数据类型为String,则Map.Entry的数据类型为<Integer,String>。

接下来我们将结合代码来具体学习Map相关知识。

二、Map的基本操作代码 Map入门

Key数据类型为String类型,Value数据类型为Integer类型的Map

public static void main(String[] args) {
        //若要使用Map,我们需要导入import java.util.HashMap;与import java.util.Map;
        //我们使用泛型来约束Map的数据类型,Key为String数据类型,Value为Integer数据类型
        Map<String,Integer> map=new HashMap<>();
        //使用put()方法来添加数据
        map.put("zhangsan",18);
        map.put("lisi",19);
        map.put("wangwu",20);
        map.put("chenliu",21);
        //普通打印
        System.out.println(map);
    }

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


接下来我们探讨Key的值不可重复(当Key的值重复的时候,后面插入的对象会将之前插入的具有相同的Key值的对象覆盖掉),Value的值可重复此问题

Key数据类型为Integer类型,Value数据类型为double类型的Map

其中第四对象和第五对象的Value值相同,第三对象与第六对象的Key值相同。

public static void main(String[] args) {
        //若要使用Map,我们需要导入import java.util.HashMap;与import java.util.Map;
        //我们使用泛型来约束Map的数据类型,Key为Integer数据类型,Value为Double数据类型
        Map<Integer, Double> map=new HashMap<>();
        //使用put()方法来添加数据
        map.put(18,18.99);//第一对象
        map.put(19,20.00);//第二对象
        map.put(20,59.99);//第三对象
        map.put(21,20.11);//第四对象
        map.put(22,20.11);//第五对象
        map.put(20,99.99);//第六对象
        //普通打印
        System.out.println(map);
    }

运行结果:(我们发现后面插入的第六对象将之前插入的第三对象给覆盖掉了,而第四对象与第五对象的Value值重复则不会带来任何影响
在这里插入图片描述


三、Map的遍历操作 Map基础

Map的遍历分为调用keySet()方法遍历和entrySet()方法遍历

Map调用keySet()方法遍历

public static void main(String[] args) {
        //若要使用Map,我们需要导入import java.util.HashMap;与import java.util.Map;
        //我们使用泛型来约束Map的数据类型,Key为Integer数据类型,Value为Double数据类型
        Map<Integer, Double> map=new HashMap<>();
        //使用put()方法来添加数据
        map.put(18,18.99);//第一对象
        map.put(19,20.00);//第二对象
        map.put(20,59.99);//第三对象
        map.put(21,20.11);//第四对象
        map.put(22,20.11);//第五对象
        map.put(20,99.99);//第六对象
        
        //调用keySet方法遍历
            //在Map遍历中Key占据着主导地位,可以通过Key值找到对应的Value值
            //调用keySet()方法,Set<>泛型约束应与Key的数据类型一致
            //例如在本代码中,Map<Integer, Double>,Key的数据类型为Integer,因此Set<>泛型约束也应当为Integer
            //Set<Integer> set11=map.keySet();代码的意思为将Map中所有Key值存入Set集合(18,19,20,21,22)
            //那么set11即为Key值集合
            Set<Integer> set11=map.keySet();

            //使用forEach()语句遍历,Integer为set11的数据类型,i为set11的复用名(相当于set11)
            //那么i就成为了Key值
            for(Integer i:set11){
                //在Map遍历中Key占据着主导地位,可以通过Key值找到对应的Value值
                //接下来我们要根据Key值来查找各个Key值对应的Value值
                //Value数据类型为Double,设置一个Double变量来存储Value
                //map.get(i);代码意思为根据i(Key值)找到相对应的Value值
                Double dou=map.get(i);
                
                //打印输出
                System.out.println("Key的值为:"+i+"    "+"Value的值为:"+dou);
            }
    }

运行结果:(我们发现输出顺序与插入顺序不一致,这是因为我们使用了Set集合来遍历Map,Set集合具有存取数据不一致的问题
在这里插入图片描述


Map调用entrySet()方法遍历

public static void main(String[] args) {
        //若要使用Map,我们需要导入import java.util.HashMap;与import java.util.Map;
        //我们使用泛型来约束Map的数据类型,Key为Integer数据类型,Value为Double数据类型
        Map<Integer, Double> map=new HashMap<>();
        //使用put()方法来添加数据
        map.put(18,18.99);//第一对象
        map.put(19,20.00);//第二对象
        map.put(20,59.99);//第三对象
        map.put(21,20.11);//第四对象
        map.put(22,20.11);//第五对象
        map.put(20,99.99);//第六对象
        //调用entrySet方法遍历
            //调用entrySet()方法,Set<>泛型约束应与Map.Entry的数据类型一致,即<Integer, Double>
            //<Key,Value>键值对,在Java语言中又被称之为Entry/entry,Map.Entry就相当于Student.name,若name的数据类型为String,则Student.name的数据类型为String,同理若<key,value>中key的数据类型为Integer,value的数据类型为String,则Map.Entry的数据类型为<Integer,String>,在这里就是<Integer, Double>。
            //Set<Map.Entry<Integer,Double>> set11=map.entrySet();代码的意思为将Map中所有(Key,Value)值存入Set集合[(18,18.99),(19,20.00),(20,99.99),(21,20.11),(22,20.11)]
            //那么set11即为(Key,Value)值集合
            Set<Map.Entry<Integer,Double>> set11=map.entrySet();
            //使用forEach()语句遍历,Integer为set11的数据类型,i为set11的复用名(相当于set11)
            //那么i就成为了(Key,Value)值
            for(Map.Entry<Integer,Double> i:set11){
                //打印输出,直接调用getKey()方法得到Key值,直接调用getValue()得到Value值
                System.out.println("Key的值为:"+i.getKey()+"    "+"Value的值为:"+i.getValue());
            }
    }

运行结果:(我们发现输出顺序与插入顺序不一致,这是因为我们使用了Set集合来遍历Map,Set集合具有存取数据不一致的问题
在这里插入图片描述


四、案例Map集合储存学生对象并遍历 Map基础强化

需求:创建一个Map集合,键是学生对象(Student),值是籍贯(String)。
要求:存储三个键值对元素(Entry),并遍历
Student类

public class Student {
    private String name;
    private int age;

    public Student() {
    }

    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

Map遍历输出

public static void main(String[] args) {
        //若要使用Map,我们需要导入import java.util.HashMap;与import java.util.Map;
        //我们使用泛型来约束Map的数据类型,Key为Student数据类型,Value为String数据类型
        Map<Student, String> map=new HashMap<>();
        //创建Student对象元素
        Student student1=new Student("zhangsan",18);
        Student student2=new Student("lisi",29);
        Student student3=new Student("wangwu",33);
        //使用put()方法来添加数据
        map.put(student1,"北京");
        map.put(student2,"上海");
        map.put(student3,"广州");
        //调用keySet方法遍历
        //在Map遍历中Key占据着主导地位,可以通过Key值找到对应的Value值
        //调用keySet()方法,Set<>泛型约束应与Key的数据类型一致
        //例如在本代码中,Map<Student, String>,Key的数据类型为Student,因此Set<>泛型约束也应当为Student
        //Set<Student> set11=map.keySet();代码的意思为将Map中所有Key值存入Set集合(student1,student2,student3)
        //那么set11即为Key值集合
        Set<Student> set11=map.keySet();

        //使用forEach()语句遍历,Student为set11的数据类型,i为set11的复用名(相当于set11)
        //那么i就成为了Key值
        for(Student i:set11){
            //在Map遍历中Key占据着主导地位,可以通过Key值找到对应的Value值
            //接下来我们要根据Key值来查找各个Key值对应的Value值
            //Value数据类型为String,设置一个String变量来存储Value
            //map.get(i);代码意思为根据i(Key值)找到相对应的Value值
            String str=map.get(i);

            //打印输出
            System.out.println("Key的值为:"+i+"    "+"Value的值为:"+str);
        }

        System.out.println("====华丽的分割线====");

        //调用entrySet方法遍历
        //调用entrySet()方法,Set<>泛型约束应与Map.Entry的数据类型一致,即<Student, String>
        //<Key,Value>键值对,在Java语言中又被称之为Entry/entry,Map.Entry就相当于Student.name,若name的数据类型为String,则Student.name的数据类型为String,同理若<key,value>中key的数据类型为Integer,value的数据类型为String,则Map.Entry的数据类型为<Integer,String>,在这里就是<Student, String>。
        //Set<Map.Entry<Student, String>> set22=map.entrySet();代码的意思为将Map中所有(Key,Value)值存入Set集合[(Student("zhangsan",18),"北京"),(Student("lisi",29),“上海”),(Student("wangwu",33),“广州”)]
        //那么set22即为(Key,Value)值集合
        Set<Map.Entry<Student, String>> set22=map.entrySet();
        //使用forEach()语句遍历,Integer为set11的数据类型,i为set22的复用名(相当于set22)
        //那么i就成为了(Key,Value)值
        for(Map.Entry<Student, String> i:set22){
            //打印输出,直接调用getKey()方法得到Key值,直接调用getValue()得到Value值
            System.out.println("Key的值为:"+i.getKey()+"    "+"Value的值为:"+i.getValue());
        }
    }

运行结果:(我们发现输出顺序与插入顺序不一致,这是因为我们使用了Set集合来遍历Map,Set集合具有存取数据不一致的问题
在这里插入图片描述


OK!!!结束!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/2452.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

单片机中按键检测函数详细分析经典

​ 目录 一、如何进行按键检测 1.从裸机的角度分析 2.从OS的角度分析 二、最简单的按键检测程序 三、为什么要了解FIFO 四、什么是FIFO 五、按键FIFO的优点 六、按键 FIFO 的实现 1.定义结构体 2.将键值写入FIFO 3.从FIFO读出键值 4.按键检测程序 5.按键扫描 7.…

简易的html5视频播放倍速代码写法

HTML5视频标签有一个叫做playbackRate的属性&#xff0c;用于设置倍速播放。例如设置播放速度为2倍&#xff0c;可以写成&#xff1a; <video src"video.mp4" autoplay controls playbackRate"2"></video> 同时&#xff0c;可以使用JavaScri…

推荐 5 个好玩的 ChatGPT 开源应用

推荐 5 个基于 ChatGPT 的开源应用&#xff1a;基于强大的 GPT 大模型能力&#xff0c;看能开出什么好玩有趣实用的应用。本期推荐开源项目目录&#xff1a;1. 基于 OpenAI 的翻译应用2. 让 ChatGPT 支持图片3. 你的 AI 助手4. 可以与 ChatGPT 联动的智能音箱5. ChatGPT 快捷键…

【thingsboard】实现设备联动

本实验实现:通过在thingsboard中配置规则链和数据解析脚本,实现智能场景下的设备联动 点赞收藏,评论区获取原文 0.实验结果 描述:节点RAK3272模拟采集温度值,上传thingsboard平台;温度值大于32℃,控制节点LM401的led灯亮(模拟报警功能);温度值低于32℃,控制led灯灭(…

借助CatGPT让turtlesim小乌龟画曲线

注意这里是CatGPT&#xff0c;不等同OpenAI的ChatGPT&#xff0c;但是用起来十分方便&#xff0c;效果也还行。详细说明ROS机器人turtlesim绘制曲线需要注意哪些ROS机器人turtlesim绘制曲线需要注意以下几点&#xff1a;绘制曲线前需要设置好turtlesim的初始位置和方向&#xf…

【JUC进阶】从源码角度万字总结ReentrantLock与AQS

文章目录1. 什么是ReentrantLock2. AQS2.1 CLH队列3. ReentrantLock源码解析3.1 非公平锁 NonfairSync3.2 公平锁 FairSync3.3 解锁1. 什么是ReentrantLock ReentrantLock是一个互斥锁&#xff0c;能够实现共享数据做互斥同步&#xff0c;这样在同一个时刻保证了只有一个线程能…

iOS 紧急通知

一般通知 关于通知的各种配置和开发&#xff0c;可以参考推送通知教程&#xff1a;入门 – Kodeco&#xff0c;具有详细步骤。 紧急通知表现 紧急通知不受免打扰模式和静音模式约束。当紧急通知到达时&#xff0c;会有短暂提示音量和抖动&#xff08;约2s&#xff09;。未锁…

企业增长秘诀丨设立优质的帮助中心,加深用户产品使用深度,促进产品转化

客户的留存问题一直备受企业关注&#xff0c;留存率的高低反应了产品的真实状况&#xff0c;将直接影响企业后期的发展规划。下文将为大家剖析下产品中客户的转化流程&#xff0c;以及如何提高产品的使用深处与复购率。 产品中&#xff0c;从客户生命周期角度&#xff0c;可分…

ChatGPT和百度文心一言写用例,谁更强?

文心一言发布的第一时间&#xff0c;就排队申请了邀请码&#xff0c;昨晚看了下&#xff0c;邀请码已经到手&#xff0c;索性就拿一个例子试了一下&#xff0c;看看哪个能够真正意义上的提高生产力&#xff0c;最简单的录制了个GIF动画如下&#xff1a;问题&#xff1a;你是一个…

Web前端:6种基本的前端编程语言

如果你想在前端web开发方面开始职业生涯&#xff0c;学习JavaScript是必须的。它是最受欢迎的编程语言&#xff0c;它功能广泛&#xff0c;功能强大。但JavaScript并不是你唯一需要知道的语言。HTML和CSS对于前端开发至关重要。他们将帮助你开发用户友好的网站和应用程序。什么…

【Linux】动静态库

认识动静态库静态库&#xff08;.a&#xff09;&#xff1a;程序在编译链接的时候把库的代码链接到可执行文件中。程序运行的时候将不再需要静态库动态库&#xff08;.so&#xff09;&#xff1a;程序在运行的时候才去链接动态库的代码&#xff0c;多个程序共享使用库的代码。一…

MySQL注入秘籍【绕过篇】

MySQL注入秘籍【绕过篇】1.通用方法2.绕过空格3.绕过引号4.绕过逗号,5.绕过等号6.绕过and/or7.绕过注释符8.绕过函数检测1.通用方法 编码 编码无非就是hex、url等等编码&#xff0c;让传到数据库的数据能够解析的即可&#xff0c;比如URL编码一般在传给业务的时候就会自动解码…

【沐风老师】3DMAX交通流插件TrafficFlow使用方法详解

TrafficFlow交通流插件&#xff0c;模拟生成车流、人流动画。 【版本要求】 3dMax 2008及更高版本 【安装方法】 无需安装直接拖动插件脚本文件到3dMax视口中打开。 【快速开始】 1.创建车辆对象和行车路径。 2.打开TrafficFlow插件&#xff0c;先选择“车辆”对象&#xff0…

大数据处理学习笔记2.1 初识Spark

文章目录零、本节学习目标一、Spark的概述&#xff08;一&#xff09;Spark的组件1、Spark Core2、Spark SQL3、Spark Streaming4、MLlib5、Graph X6、独立调度器、Yarn、Mesos&#xff08;二&#xff09;Spark的发展史1、发展简史2、目前最新版本二、Spark的特点&#xff08;一…

对void的深度理解

作者&#xff1a;小树苗渴望变成参天大树 作者宣言&#xff1a;认真写好每一篇博客 作者gitee:gitee 如 果 你 喜 欢 作 者 的 文 章 &#xff0c;就 给 作 者 点 点 关 注 吧&#xff01; void前言一、 void 关键字二、 void修饰函数返回值和参数三、void指针3.1void * 定义的…

BeanPostProcessor原理分析

文章目录一、BeanPostProcessor的作用1. 源码2. 使用案例二、Spring生命周期中的BeanPostProcessor三、BeanPostProcessor对PostConstruct的支持四、BeanPostProcessor中的顺序性五、总结一、BeanPostProcessor的作用 BeanPostProcessor提供了初始化前后回调的方法&#xff0c;…

百度文心一言正式亮相

OpenAI 刚发布了 GPT-4&#xff0c;百度预热已久的人工智能生成式对话产品也终于亮相了。昨天下午&#xff0c;文心一言 (ERNIE Bot)—— 百度全新一代知识增强大语言模型、文心大模型家族的新成员&#xff0c;正式在百度总部 “挥手点江山” 会议室里发布。 发布会一开场&…

Linux第一个小程序git三板斧

目录 1.Linux项目自动化构建工具 - make/makefile 1.1.makefile原理 1.2.项目清理 2.第一个小程序 - 进度条 3.git三板斧 1.Linux项目自动化构建工具 - make/makefile make是一条命令&#xff0c;makefile是一个文件&#xff0c;两个搭配使用&#xff0c;完成项目自动化构建。 …

HashData携手新炬网络 共推国产云数仓产业发展

3月22日&#xff0c;酷克数据宣布与国内知名IT智能运维服务商新炬网络签署战略合作协议&#xff0c;新炬网络成为酷克数据核心战略合作伙伴。 双方约定&#xff0c;将通过优势互补、资源共享的方式&#xff0c;建立长期合作模式和信息共享机制&#xff0c;在数据库相关领域展开…

Prometheus监控实战之Blackbox_exporter黑盒监测

1 Blackbox_exporter应用场景 blackbox_exporter是Prometheus官方提供的exporter之一&#xff0c;可以提供HTTP、HTTPS、DNS、TCP以及ICMP的方式对网络进行探测。 1.1 HTTP 测试 定义 Request Header信息 判断 Http status / Http Respones Header / Http Body内容 1.2 TC…