Java基础知识之HashMap的使用

一、HashMap介绍

HashMap是Map接口的一个实现类(HashMap实现了Map的接口),它具有Map的特点。HashMap的底层是哈希表结构。

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>。在HashMap与TreeMap中均可使用Map.Entry。

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

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

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

public static void main(String[] args) {
        //若要使用HashMap,我们需要导入import java.util.HashMap;
        //我们使用泛型来约束HashMap的数据类型,Key为Integer数据类型,Value为String数据类型
        HashMap<Integer, String> hashMap = new HashMap<>();
        //使用put()方法来添加数据
        hashMap.put(100, "北京");
        hashMap.put(99, "上海");
        hashMap.put(98, "广州");
        //普通打印输出
        System.out.println(hashMap);
    }

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


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

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

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

public static void main(String[] args) {
        //若要使用HashMap,我们需要导入import java.util.HashMap;
        //我们使用泛型来约束HashMap的数据类型,Key为Integer数据类型,Value为String数据类型
        HashMap<Integer, String> hashMap = new HashMap<>();
        //使用put()方法来添加数据
        hashMap.put(97, "北京");//第一对象
        hashMap.put(98, "上海");//第二对象
        hashMap.put(99, "广州");//第三对象
        hashMap.put(99, "深圳");//第四对象
        hashMap.put(100, "北京");//第五对象
        //打印输出
        System.out.println(hashMap);
    }

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

在这里插入图片描述


三、HashMap的遍历操作 HashMap基础

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

HashMap调用keySet()方法遍历

public static void main(String[] args) {
        //若要使用HashMap,我们需要导入import java.util.HashMap;
        //我们使用泛型来约束HashMap的数据类型,Key为Integer数据类型,Value为String数据类型
        HashMap<Integer, String> hashMap = new HashMap<>();
        //使用put()方法来添加数据
        hashMap.put(97, "北京");//第一对象
        hashMap.put(98, "上海");//第二对象
        hashMap.put(99, "广州");//第三对象
        hashMap.put(99, "深圳");//第四对象
        hashMap.put(100, "北京");//第五对象
        //调用keySet方法遍历
        //在HashMap遍历中Key占据着主导地位,可以通过Key值找到对应的Value值
        //调用keySet()方法,Set<>泛型约束应与Key的数据类型一致
        //例如在本代码中,HashMap<Integer, String>,Key的数据类型为Integer,因此Set<>泛型约束也应当为Integer
        //Set<Integer> set11=hashMap.keySet();代码的意思为将HashMap中所有Key值存入Set集合(97,98,99,100)
        //那么set11即为Key值集合
        Set<Integer> set11=hashMap.keySet();

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

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

运行结果:

在这里插入图片描述


HashMap调用entrySet()方法遍历

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

运行结果:

在这里插入图片描述

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

需求:创建一个Map集合,Key键是学生对象(Student),Value值是籍贯(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 +
                '}';
    }
}

HashMap遍历输出

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

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

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

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

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

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


OK!!!结束!!!

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

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

相关文章

5个高清/4K视频素材网站,免费下载。

本期跟大家分享5个超好用的视频素材网站&#xff0c;4K质量&#xff0c;免费可商用。 1、菜鸟图库 https://www.sucai999.com/video.html?vNTYwNDUx 菜鸟图库主要提供设计素材为主&#xff0c;自媒体相关素材也很多&#xff0c;像商用图片、背景图、视频素材、音频素材都很齐…

算法刷题总结 (二) 回溯与深广搜算法

算法总结2 回溯与深广搜算法一、理解回溯算法1.1、回溯的概念1.2、回溯法的效率1.3、回溯法问题分类1.4、回溯法的做题步骤二、经典问题2.1、组合问题2.1.1、77. 组合 - 值不重复2.1.2、216.组合总和III - 值不重复且等于目标值2.1.3、17. 电话号码的字母组合 - 双层回溯2.1.4、…

KafKa知识汇总

前言 汇总相关知识 Kafka快速实战与基本原理详解

LeetCode:215. 数组中的第K个最大元素

&#x1f34e;道阻且长&#xff0c;行则将至。&#x1f353; &#x1f33b;算法&#xff0c;不如说它是一种思考方式&#x1f340;算法专栏&#xff1a; &#x1f449;&#x1f3fb;123 一、&#x1f331;215. 数组中的第K个最大元素 题目描述&#xff1a;给定整数数组nums和整…

Django 之 Cookie 和 Session

3. Cookie 和 Session 会话 因为 HTTP 协议是无状态的&#xff0c;每次浏览器请求 request都是无状态的&#xff0c;后台服务器无法识别当前请求与上一次请求及之后请求是否为同一用户。 对于静态网站来说无所谓&#xff08;所有用户看到的都是一样的&#xff09;&#xff0c…

【C++】引用详细解析

目录引用的概念引用的用法引用的特性常引用&#xff08;涉及权限的放大与缩小&#xff09;引用的使用场景**作参数****作返回值**正确使用引用返回传值、传引用效率比较引用和指针的区别引用的概念 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0…

干货 | 开关电源的PCB布线设计技巧—如何降低EMI?

开关电源PCB排版是开发电源产品中的一个重要过程。许多情况下&#xff0c;一个在纸上设计得非常完美的电源可能在初次调试时无法正常工作&#xff0c;原因是该电源的PCB排版存在着许多问题。为了适应电子产品飞快的更新换代节奏&#xff0c;产品设计工程师更倾向于选择在市场上…

【Zblog建站】搭建属于自己的博客网站,并内网穿透实现公网访问

文章目录1. 前言2. Z-blog网站搭建2.1 XAMPP环境设置2.2 Z-blog安装2.3 Z-blog网页测试2.4 Cpolar安装和注册3. 本地网页发布3.1. Cpolar云端设置3.2 Cpolar本地设置4. 公网访问测试5. 结语1. 前言 想要成为一个合格的技术宅或程序员&#xff0c;自己搭建网站制作网页是绕不开…

第十四届蓝桥杯三月真题刷题训练——第 20 天

目录 第 1 题&#xff1a;纸张尺寸 问题描述 输入格式 输出格式 样例输入1 样例输出1 样例输入 2 样例输出 2 运行限制 代码&#xff1a; 解析&#xff1a; 第 2 题&#xff1a;最大数字 第 3 题&#xff1a;全排列的价值_递推公式 问题描述 输入格式 输出格式…

【中级软件设计师】—操作系统考点总结篇(二)

【中级软件设计师】—操作系统考点总结篇&#xff08;二&#xff09; 1.操作系统概述 1.1操作系统的功能 1.2 特殊的操作系统 1.3 进程的概念和状态 进程与程序的区别&#xff1a; 进程是程序的一次执行过程&#xff0c;没有程序就没有进程 程序是一个静态的概念&#xff0c;…

flowable-ui

一、介绍 flowable-ui主要用于画流程图,之后再使用flowable整合Spring Boot。Flowable提供了一个web UI应用程序来演示和利用Flowable项目提供的功能。 flowable-ui的官网文档地址为: https://www.flowable.com/open-source/docs/bpmn/ch14-Applications/ 二、安装flowab…

Counterpoint发布颈戴式耳机市场报告,苹果Find My加持不易丢

根据市场调查机构 Counterpoint 公布的 2022 年第 4 季度报告&#xff0c;一加凭借着 20.2% 的市场占有率&#xff0c;成为印度市场最大的颈戴式耳机市场厂商。 一加以 20.2% 的市场占有率领先&#xff0c;boAt 以 16% 的份额位居第二。一加云耳 Z2 已经连续 3 个季度成为印度…

【CodeForces】Codeforces Round 859 (Div. 4) D

嘿嘿嘿&#xff0c;CF虐我千百遍&#xff0c;我待CF如初见&#xff01; &#xff08;doge&#xff09; 目录 题目含义&#xff1a; 前缀和&#xff1a; 代码 &#x1f386;音乐分享&#xff08;点击链接可以听哦&#xff09; A Hundred Miles&#xff08;一百英里&#xff09;…

JDBC——Java数据库连接

文章目录一、数据库工具类二、JDBC—— Java数据库连接三、执行DML语句四、执行DQL语句五、关联查询六、执行预编译SQL语句七、SELECT语句八、练习创建表:student1九、向student1表中插入100条数据十、删除名字为Test20---Test100的学生十一、将student1表中所有test学生的年龄…

基于深度学习的花卉检测与识别系统(YOLOv5清新界面版,Python代码)

摘要&#xff1a;基于深度学习的花卉检测与识别系统用于常见花卉识别计数&#xff0c;智能检测花卉种类并记录和保存结果&#xff0c;对各种花卉检测结果可视化&#xff0c;更加方便准确辨认花卉。本文详细介绍花卉检测与识别系统&#xff0c;在介绍算法原理的同时&#xff0c;…

在不丢失数据的情况下解锁锁定的 Android 手机的 4 种方法

尽管您可以使用指纹解锁手机&#xff0c;但大多数智能手机都需要 PIN 码、图案或字母数字代码作为主密码。如果您有一段时间没有输入手机密码&#xff0c;很容易忘记。正是由于这个原因&#xff0c;即使您打开了指纹解锁&#xff0c;大多数智能手机也会让您每天至少输入一次 PI…

Pandas的DataFrame的生产,DF数据查看

这篇文档介绍了 Pandas 的入门使用方法。Pandas 是 Python 的一个数据分析库&#xff0c;可以方便地操作数据和进行数据分析。 本节以下列方式导入 Pandas 与 NumPy&#xff1a; In [1]: import numpy as npIn [2]: import pandas as pd#生成对象 用值列表生成 Seriesopen in…

并发编程(五)-ExecutorService源码分析

一、ExecutorService是什么?ExecutorService 是 Java 中的一个接口&#xff0c;它扩展了 Executor 接口&#xff0c;并提供了更多的方法来处理多线程任务。它是 Java 中用于执行多线程任务的框架之一&#xff0c;可以创建一个线程池&#xff0c;将多个任务提交到线程池中执行。…

【C++进阶】十一、哈希的应用---布隆过滤器(二)

目录 一、布隆过滤器提出 二、布隆过滤器概念 三、布隆过滤器实现 3.1 布隆过滤器的插入 3.2 布隆过滤器的查找 3.3 布隆过滤器的删除 3.4 完整代码 四、布隆过滤器优点 五、布隆过滤器缺陷 一、布隆过滤器提出 在注册账号设置昵称的时候&#xff0c;有些软件要求每个…

元宇宙、区块链 通俗易懂

什么是区块链&#xff1f;比特币挖矿是什么&#xff1f;元宇宙是什么&#xff1f;Web(万维网)的三权化进化&#xff1a;基于此&#xff0c;介绍下“元宇宙”。1992年&#xff0c;美国作家史蒂芬森在《雪崩》一书中首次提出了“元宇宙(Metaverse)”的概念。元宇宙实际上就是一种…