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;}@Overridepublic 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!!!结束!!!
相关文章:
Java基础知识之HashMap的使用
一、HashMap介绍 HashMap是Map接口的一个实现类(HashMap实现了Map的接口),它具有Map的特点。HashMap的底层是哈希表结构。 Map是用于保存具有映射关系的数据集合,它具有双列存储的特点,即一次必须添加两个元素…...
面试--每日一经
操作系统 死锁 死锁:是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。 死锁的四个必要条件 互斥条件:一个资源每次只能被一个进…...
JavaSE进阶之(十六)枚举
十六、枚举16.1 背景16.2 枚举类型16.3 EnumSet 和 EnumMap01、EnumSet02、EnumMap16.1 背景 在 Java 语言中还没有引入枚举类型之前,表示枚举类型的常用模式是声明一组 int 类型的常量,常常用的就是: public static final int SPRING 1; …...
全同态加密:TFHE
参考文献: Cheon J H, Stehl D. Fully homomophic encryption over the integers revisited[C]//Advances in Cryptology–EUROCRYPT 2015: 34th Annual International Conference on the Theory and Applications of Cryptographic Techniques, Sofia, Bulgaria, …...
【计算机二级】综合题目
计算机二级python真题 文章目录计算机二级python真题一、《大学慕课 两问 》二、综合应用题——价值链三、基本操作题 ——信息输出一、《大学慕课 两问 》 附件中的文件data.txt 是教育部爱课程网中国大学MOOC平台的某个 HTML页面源文件,里面包含了我国参与MOOC建设的一批大学…...
初识Kafka
介绍 Kafka Kafka 是一款基于发布与订阅的消息系统。 用生产者客户端 API 向 Kafka 生产消息,用消费者客户端 API 从 Kafka 读取这些消息。 Kafka 使用 Zookeeper 保存元数据信息。 Kafka 0.9 版本之前,除了 broker 之外, 消费者也会使用…...
【JavaEE】线程的状态
哈喽,大家好~我是保护小周ღ,本期为大家带来的是 Java 多线程的 线程的状态,New 新建状态,Runnable 运行状态,Blocked 阻塞状态,waiting 等待状态,Time_Waiting 超时等待状态,Termin…...
7个最受瞩目的 Python 库,提升你的开发效率
当今时代,数据分析和处理已经成为了各行各业中不可或缺的一环。Python作为一种非常流行的编程语言,为我们提供了许多强大的工具和库来处理不同类型的数据。 在这篇文章中,我将向您介绍七个非常有用的Python库,这些库各自有着独特…...
这些IT行业趋势,将改变2023
上一周,你被"AI"刷屏了吗? 打开任何一家科技媒体,人工智能都是不变的热门话题。周初大家还在用ChatGPT写论文、查资料、写代码,到周末的时候大家已经开始用GPT-4图像识别来做饭、Microsoft 365 Copilot 来写PPT了。 GP…...
蓝桥杯每日一真题——[蓝桥杯 2021 省 B] 杨辉三角形(二分+规律)
文章目录[蓝桥杯 2021 省 B] 杨辉三角形题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1提示思路:全部代码:[蓝桥杯 2021 省 B] 杨辉三角形 题目描述 下面的图形是著名的杨辉三角形: 如果我们按从上到下、从左到右的顺序把所有数排成一列&…...
<C++> 类和对象(下)
1.const成员函数将const修饰的“成员函数”称之为const成员函数,const修饰类成员函数,实际修饰该成员函数隐含的this指针,表明在该成员函数中不能对类的任何成员进行修改。class A { public:void Print() //这里隐藏了A* this指针{cout <…...
基于Springboot+Vue2前后端分离框架的智慧校园系统源码,智慧学校源码+微信小程序+人脸电子班牌
▶ 智慧校园开发环境: 1、使用springboot框架Javavue2 2、数据库MySQL5.7 3、移动端小程序使用小程序原生语音开发 4、电子班牌固件安卓7.1;使用Java Android原生 5、elmentui ,Quartz,jpa,jwt 智慧校园结构导图▶ 这…...
JavaEE-线程安全问题
1.线程安全的概念 如果多线程环境下代码运行的结果是符合我们预期的,即在单线程环境应该的结果,则说这个程序是线 程安全的. 为啥会出现线程安全问题? 本质原因: 线程在系统中的调度是无序的/随机的 (抢占式执行). 2.开始说明 先看个线程不安全的例子…...
【Node.js】身份认证,Cookie和Session的认证机制,express中使用session认证和JWT认证
Node.jsWeb开发模式如何选择Web开发模式身份认证什么是身份认证为什么要身份认证不同开发模式的身份认证Session认证机制提高身份认证的安全性Session的工作原理Express中使用Session认证Session认证机制的局限性JWT认证机制JWT的工作原理JWT的组成部分Express中使用JWT在登录成…...
Redis删除策略和淘汰策略
一、删除策略 删除策略就是针对已过期数据的处理策略。 针对过期数据要进行删除的时候都有哪些删除策略呢? 1.定时删除2.惰性删除3.定期删除1、立即删除 当key设置有过期时间,且过期时间到达时,由定时器任务立即执行对键的删除操作。 优…...
LFM雷达实现及USRP验证【章节2:LFM雷达测距】
目录 1. 参数设计 几个重要的约束关系 仿真参数设计 2. matlab雷达测距代码 完整源码 代码分析 回顾:LFM的基本原理请详见第一章 本章节将介绍LFM雷达测距的原理及实现 1. 参数设计 几个重要的约束关系 带通采样定理: 因此如果我们B80MHz时&a…...
菜鸟刷题Day5
⭐作者:别动我的饭 ⭐专栏:菜鸟刷题 ⭐标语:悟已往之不谏,知来者之可追 一.一维数组的动态和:1480. 一维数组的动态和 - 力扣(LeetCode) 描述 给你一个数组 nums 。数组「动态和」的计算公式…...
已解决AttributeError:module tensorflow no attribute app异常的正确解决方法,亲测有效!!!
已解决AttributeError:module tensorflow no attribute app异常的正确解决方法,亲测有效!!! 文章目录报错问题解决方法福利报错问题 粉丝群里面的一个小伙伴敲代码时发生了报错(当时他心里瞬间凉了一大截&…...
Hadoop集群环境配置搭建
一、简单介绍 Hadoop最早诞生于Cutting于1998年左右开发的一个全文文本搜索引擎 Lucene,这个搜索引擎在2001年成为Apache基金会的一个子项目,也是 ElasticSearch等重要搜索引擎的底层基础。 项目官方:https://hadoop.apache.org/ 二、Linux环…...
Thread类的基本用法
Thread类的基本用法🔎1.线程创建🌻继承Thread类🌼继承Thread重写run()方法🌼继承Thread匿名内部类🌻实现Runnable接口🌼实现Runnable接口重写run()方法🌼实现Runnable接口匿名内部类ἳ…...
【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器
一.自适应梯度算法Adagrad概述 Adagrad(Adaptive Gradient Algorithm)是一种自适应学习率的优化算法,由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率,适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...
Zustand 状态管理库:极简而强大的解决方案
Zustand 是一个轻量级、快速和可扩展的状态管理库,特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...
连锁超市冷库节能解决方案:如何实现超市降本增效
在连锁超市冷库运营中,高能耗、设备损耗快、人工管理低效等问题长期困扰企业。御控冷库节能解决方案通过智能控制化霜、按需化霜、实时监控、故障诊断、自动预警、远程控制开关六大核心技术,实现年省电费15%-60%,且不改动原有装备、安装快捷、…...
ESP32读取DHT11温湿度数据
芯片:ESP32 环境:Arduino 一、安装DHT11传感器库 红框的库,别安装错了 二、代码 注意,DATA口要连接在D15上 #include "DHT.h" // 包含DHT库#define DHTPIN 15 // 定义DHT11数据引脚连接到ESP32的GPIO15 #define D…...
页面渲染流程与性能优化
页面渲染流程与性能优化详解(完整版) 一、现代浏览器渲染流程(详细说明) 1. 构建DOM树 浏览器接收到HTML文档后,会逐步解析并构建DOM(Document Object Model)树。具体过程如下: (…...
【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...
Python ROS2【机器人中间件框架】 简介
销量过万TEEIS德国护膝夏天用薄款 优惠券冠生园 百花蜂蜜428g 挤压瓶纯蜂蜜巨奇严选 鞋子除臭剂360ml 多芬身体磨砂膏280g健70%-75%酒精消毒棉片湿巾1418cm 80片/袋3袋大包清洁食品用消毒 优惠券AIMORNY52朵红玫瑰永生香皂花同城配送非鲜花七夕情人节生日礼物送女友 热卖妙洁棉…...
【C++特殊工具与技术】优化内存分配(一):C++中的内存分配
目录 一、C 内存的基本概念 1.1 内存的物理与逻辑结构 1.2 C 程序的内存区域划分 二、栈内存分配 2.1 栈内存的特点 2.2 栈内存分配示例 三、堆内存分配 3.1 new和delete操作符 4.2 内存泄漏与悬空指针问题 4.3 new和delete的重载 四、智能指针…...
RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)
RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发,后来由Pivotal Software Inc.(现为VMware子公司)接管。RabbitMQ 是一个开源的消息代理和队列服务器,用 Erlang 语言编写。广泛应用于各种分布…...
4. TypeScript 类型推断与类型组合
一、类型推断 (一) 什么是类型推断 TypeScript 的类型推断会根据变量、函数返回值、对象和数组的赋值和使用方式,自动确定它们的类型。 这一特性减少了显式类型注解的需要,在保持类型安全的同时简化了代码。通过分析上下文和初始值,TypeSc…...
