Java集合进阶——双列集合

2024-04-15 18:20
文章标签 java 进阶 集合 双列

本文主要是介绍Java集合进阶——双列集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.双列集合Map

1.体系结构框架

6bb13509829644358058cd5afa136d4c.png 

2.双列集合的特点

①双列集合一次添加一对数据,分别为键和值,这个整体我们称为键值对——Entry

②键和值为一一对应关系

③键不能重复,值可以重复

0ac031308c7e49c5b278885c40a51676.png

二. Map

122c3c34d60e4e7abcf8918dc6f4058a.png

1.概念

public interface Map<K,V>

将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。

Map是双列集合的顶层接口,它的功能是全部双列集合都可以继承使用 

2.方法摘要

0f38fa2253b94b11a574dac579e3d163.png

⑴方法细节

①put  添加数据时若键存在,那么会将被覆盖的值返回 93a27de4e70a4cf1894e467a2ef1a6ae.png

⑵常用方法

cb5611c8aa294159882cb948a6fd5883.png

集合中最重要的莫过于增删改查,但是Map中没有定义set(修改元素)的方法

但是我们可以put集合的特殊机制进行元素的修改

03f8fdf1fa204f1cb0b6f880d9ab2f43.png

3. Map的三种遍历方式

⑴键找值遍历法

将所有的键放到一个单列集合中( keySet方法),再遍历set集合,通过Map的get方法获取每一个键对应的值

0c0a3e5b4c454fb4a559b6c98a2322f9.png

⑵键值对遍历

通过entrySet方法获取所有键值对对象,并存储到set< Map. Entry<Obj,Obj>>集合中

29a1b6474c5146c0986e6f9d5802eae5.png 

⑶ Lambda表达式遍历

79a7e34eff60428cb7eee89bcc70633f.png

三. HashMap

1.概念

HashMap是基于哈希表的Map接口的实现

其特点都是由键决定的:无序,不重复,无索引

2.特有方法

HashMap的方法与Map基本一致

getOrDefault( key,默认值)

判断哈希表中是否存在key,若存在则返回key的value值,不存在则返回默认值

这个方法可厉害了,在力扣的部分解题中很有帮助

如:如何让哈希表中的一个键key对应多个值

首先我们肯定会想到值用链表结构类型,在每次找键插值时,我们要先获取key的链表,再将value插入链表中,最后再用put覆盖将链表再次插入到key中

5774e798e44049f5b1eace53417006cd.png

3.底层原理

HashMap与HashSet的底层原理是一模一样的,都是哈希表结构

493aeea712b4453db6c4f3c620ceabc6.png

 

 

四. LinkedHashMap

1.概念

Map 接口的哈希表和链接列表实现,具有可预知(有序)的迭代顺序。此实现与 HashMap 的不同之处在于,后者维护着一个运行于所有条目的双重链接列表。此链接列表定义了迭代顺序,该迭代顺序通常就是将键插入到映射中的顺序(插入顺序)。注意,如果在映射中重新插入 键,则插入顺序不受影响

由键决定:有序,不重复,无索引

2.方法摘要

与Map一致

3.底层原理

底层数据结构依然是哈希表,但是每个键值元素额外的多了一个双链表的机制记录存储的顺序

与LinkedHashSet底层原理一致

6ae40e68179f4ea2b1818666b403e6f8.png

五. TreeMap

1.概念

基于红黑树(Red-Black tree)的 NavigableMap 实现。该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法

由键决定特性:可排序,无索引,不重复

2. TreeMap的两种排序规则

与TreeSet的排序规则一致

默认按照键的从小到大进行排序,可可以自己规定键的排序规则

方式一:实现Comparable接口指定比较规则

d8c347c0159241088cccad1a16189478.png 

c9a84dd87393474399b8ea291b170c27.png 

方式二:创建集合时传递Comparator比较器对象,指定比较规则

5e8ff0c379d246fca635b9f0a288c534.png  

3.底层原理

TreeMap与TreeSet底层原理一样,都是红黑树结构

 

六. Properties

1.概念

Properties 类表示了一个持久的属性集。Properties 可保存在流中或从流中加载。属性列表中每个键及其对应值都是一个字符串

Properties是一个双列集合,拥有Map集合所有的特点

可以把集合中的数据按照键值对的形式写到配制文件当中。也可以把配制文件中的数据读取到集合中来

1fb324abafdf4c468ebca5ec5d93f140.png

2.特有方法

⑴集合方面的操作方法

817c5625bfde4612b3f716118312aced.png

⑵与IO相关的方法

63c7669b230b48539d8190427bb5c0ef.png

其中最基础的两个方法我们务必要掌握

①store  将集合中的数据以键值对的形式读取到文件中

c6db30df080b4e91b260de348f4fd067.png

②load  将文件中的数据以键值对的形式读取到集合中

2fddc91416da43dfb1df3ee598e6fa1c.png

 

 

 

 

 

 

 

 

 

这篇关于Java集合进阶——双列集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906565

相关文章

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav