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

相关文章

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义