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

相关文章

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud

线性因子模型 - 独立分量分析(ICA)篇

序言 线性因子模型是数据分析与机器学习中的一类重要模型,它们通过引入潜变量( latent variables \text{latent variables} latent variables)来更好地表征数据。其中,独立分量分析( ICA \text{ICA} ICA)作为线性因子模型的一种,以其独特的视角和广泛的应用领域而备受关注。 ICA \text{ICA} ICA旨在将观察到的复杂信号