jdk1.8中HashSet与LinkedHashSet源码分析

2024-06-06 21:48

本文主要是介绍jdk1.8中HashSet与LinkedHashSet源码分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

注:基于JDK 1.8.0_131源码为例进行分析:

一、HashSet分析

1.1 HashSet的实现

  HashSet实现set接口,是基于HashMap或者LinkedHashMap实现的
  HashSet中封装了一个 HashMap 对象(也有可能是LinkedHashMap)来存储所有的集合元素,所有放入 HashSet 中的集合元素实际上由 HashMap 的 key 来保存,而 HashMap 的 value 则存储了一个 PRESENT,它是一个静态的 Object 对象。
  注:LinkedHashMap的实现是继承自HashMap的,所以一个LinkedHashMap对象可以复制给HashMap引用。
这里写图片描述
说明:

  • 代码块1:HashSet的实现是由HashMap<E,Object>类型的map实现。所以放入hashset集合的元素均存进了map的key中。
  • 代码块2:map中的每一个键值对<key,value>的value值均为该静态Object对象PRESENT。

1.2 HashSet中选择用HashMap还是LinkedHashMap实现?

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
结论:

  • A:前三个构造函数,即访问权限为public类型的构造函数均是以HashMap作为实现。而以LinkedHashMap作为实现的构造函数的访问权限是默认访问权限,即包内访问权限。
    即:在java编程中,通过new创建的HashSet对象均是以HashMap作为实现基础。只有在jdk中java.util包内的源代码才可能创建以LinkedHashMap作为实现的HashSet(LinkedHashSet就是通过封装一个以LinkedHashMap为实现的HashSet来实现的)。
  • B:只有包含三个参数的构造函数才是采用的LinkedHashMap作为实现。

1.3 HashSet的默认大小

这里写图片描述
说明:

  • 代码块1:HashSet中map的默认大小为HashMap的默认值,即容量为16,负载因子为0.75。
  • 代码块2:HashSet中map的容量最小值为16。

1.4 HashSet的add操作实现

这里写图片描述
即直接将键值对<e,PRESENT>放入了hashmap中。

1.5 HashSet的contains方法实现

这里写图片描述

1.6 HashSet的迭代

注:只有实现了Iterable接口的类,才能用迭代器进行遍历。
这里写图片描述
HashSet的中迭代器迭代是基于HashMap的KeySet实现的。

1.7 HashSet的序列化定制

这里写图片描述

1.8 HashSet的用处?

1、 可以在HashSet集合中存储不重复的元素。如果加入重复元素会自动覆盖。
2、 HashSet中可以出现一个为null元素。
3、 因为用new创建的HashSet对象中采用HashMap实现时,则不能保证集合中元素的顺序,即顺序是无序的。

二、LinkedHashSet分析

2.1 LinkedHashSet是通过继承HashSet进行实现的

这里写图片描述

2.2 LinkedHashSet是通过构造一个具有三个参数的HashSet进行实现的。

这里写图片描述
即:LinkedHashSet是通过继承HashSet,然后基于LinkedHashMap进行实现的

2.3 HashSet与LinkedHashSet对比总结

  • A:HashSet的public类型构造函数均是采用HashMap实现,所以HashSet能够存储不重复的对象,包括NULL。
  • B:LinkedHashSet通过继承HashSet,采用LinkedhashMap进行实现,所以LinkedHashSet除了具有HashSet的功能外,还能保证元素按照加入顺序进行排序。
        LinkedHashSet<Integer> linkedHashSet = new LinkedHashSet<>();linkedHashSet.add(11);linkedHashSet.add(33);linkedHashSet.add(44);linkedHashSet.add(22);linkedHashSet.add(55);System.out.println("LinkedHashSet输出结果:");for (Integer integer : linkedHashSet) {System.out.print(integer+" ");}System.out.println();HashSet<Integer> hashSet = new HashSet<>();hashSet.add(11);hashSet.add(33);hashSet.add(44);hashSet.add(22);hashSet.add(55);System.out.println("HashSet输出结果:");for (Integer integer : hashSet) {System.out.print(integer+" ");}System.out.println();

运行结果:

LinkedHashSet输出结果:
11 33 44 22 55 
HashSet输出结果:
33 22 55 11 44 

由结果可以看出,LinkedHashSet是按照加入顺序进行排序的。

这篇关于jdk1.8中HashSet与LinkedHashSet源码分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep

java中的HashSet与 == 和 equals的区别示例解析

《java中的HashSet与==和equals的区别示例解析》HashSet是Java中基于哈希表实现的集合类,特点包括:元素唯一、无序和可包含null,本文给大家介绍java中的HashSe... 目录什么是HashSetHashSet 的主要特点是HashSet 的常用方法hasSet存储为啥是无序的

Go中sync.Once源码的深度讲解

《Go中sync.Once源码的深度讲解》sync.Once是Go语言标准库中的一个同步原语,用于确保某个操作只执行一次,本文将从源码出发为大家详细介绍一下sync.Once的具体使用,x希望对大家有... 目录概念简单示例源码解读总结概念sync.Once是Go语言标准库中的一个同步原语,用于确保某个操

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制