浅谈Java中的LinkedHashSet哈希链表

 更新时间:2023年09月04日 08:44:51   作者:橙子  
这篇文章主要介绍了浅谈Java中的LinkedHashSet哈希链表,LinkedHashSet 是 Java 中的一个集合类,它是 HashSet 的子类,并实现了 Set 接口,与 HashSet 不同的是,LinkedHashSet 保留了元素插入的顺序,并且具有 HashSet 的快速查找特性,需要的朋友可以参考下

HashSet哈希链表

Map、Set集合存放是无序的,然而LinkedHashSet和LinkedHashMap等集合却有序

原因:LinkedHashSet与LinkedHashMap底层是通过双向链表来实现排序的。

双向链表里面的数据在逻辑上的存储是连续的,连续自然也就有顺序。

有序的原因关键在LinkedHashMap的Node 节点上。

LinkedHashMap 继承自HashMap 并且实现了Map接口。

源码如下:

/**
HashMap.Node subclass for normal LinkedHashMap entries.
*/
static class Entry<K,V> extends HashMap.Node<K,V> {
    Entry<K,V> before, after;
    Entry(int hash, K key, V value, Node<K,V> next) {
        super(hash, key, value, next);
    }
}

可以看到LinkedHashMap.Entry 继承自HashMap.Node 除了Node 本身有的几个属性外,额外增加了before after 用于指向前一个Entry 后一个Entry。

也就是说,元素之间维持着一条总的链表数据结构。正式因为这个链表才保证了LinkedHashMap的有序性。

LinkedHashSet集合也是根据元素hashCode值来决定元素存储位置,但它同时使用链表维护元素的次序,这样使得元素看起来是以插入的顺序保存的。

也就是说,当遍历LinkedHashSet集合里元素时,HashSet将会按元素的添加顺序来访问集合里的元素,因此LinkedHashSet可以保证元素按插入顺序输出。

而Set对每个对象只接受一次,里面的值不允许重复,是无序的数据结构;

LinkeHashSet是set集合的一个实现,具有set集合不重复的特点,同时具有可预测的迭代顺序,即输入顺序。

这种双链表的结构一条用于储存元素,一条用于记录顺序。

而Map Set集合内是单链表或稀疏数组,各元素之间并没有维持一条总的链表结构,所以Map和Set是无序的

LinkedHashSet的4种构造函数:

  1. 第一种构造函数初始化一个空的LinkedHashSet: LinkedHashSet( );
  2. 第二种构造函数使用Collection元素集初始化LinkedHashSet: LinkedHashSet(Collection c);
  3. 第三种构造函数用给定的容量初始化LinkedHashSet: LinkedHashSet(int capacity);
  4. 第四种构造函数通过传入的容量和填充比初始化LinkedHashSet: LinkedHashSet(int capacity, float fillRatio);

在这里插入图片描述

运行结果:

在这里插入图片描述

这两断代码我们可以得出:LinkedHashSet 底层采用双向链表实现,可以保证元素的插入顺序,又因为是HashSet的子类,所以插入的元素不能重复。

到此这篇关于浅谈Java中的LinkedHashSet哈希链表的文章就介绍到这了,更多相关Java的LinkedHashSet内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JVM内存结构相关知识解析

    JVM内存结构相关知识解析

    这篇文章主要介绍了JVM内存结构相关知识解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • 浅谈一下Java中的悲观锁和乐观锁

    浅谈一下Java中的悲观锁和乐观锁

    这篇文章主要介绍了一下Java中的悲观锁和乐观锁,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Spring复杂对象创建的方式小结

    Spring复杂对象创建的方式小结

    这篇文章主要介绍了Spring复杂对象创建的三种方式,现在使用Spring如何创建这种类型的对象?Spring中提供了三种方法来创建复杂对象,需要的朋友可以参考下
    2022-01-01
  • SpringBoot项目中使用Swagger2及注解解释的详细教程

    SpringBoot项目中使用Swagger2及注解解释的详细教程

    Swagger2是一个开源项目,用于为RESTful Web服务生成REST API文档,下面这篇文章主要给大家介绍了关于SpringBoot项目中使用Swagger2及注解解释的详细教程,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • Java适配器模式之如何灵活应对不匹配的接口

    Java适配器模式之如何灵活应对不匹配的接口

    本文介绍了Java中的适配器模式,包括对象适配器模式和接口适配器模式,适配器模式通过将一个类的接口转换成客户期望的另一个接口,解决了不同接口之间的不兼容问题,它提高了系统的灵活性、复用性和解耦性,需要的朋友可以参考下
    2024-10-10
  • 从零搭建Spring Boot脚手架整合OSS作为文件服务器的详细教程

    从零搭建Spring Boot脚手架整合OSS作为文件服务器的详细教程

    这篇文章主要介绍了从零搭建Spring Boot脚手架整合OSS作为文件服务器的详细教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • Java多线程CyclicBarrier的实现代码

    Java多线程CyclicBarrier的实现代码

    CyclicBarrier可以使一定数量的线程反复地在栅栏位置处汇集,本文通过实例代码介绍下Java多线程CyclicBarrier的相关知识,感兴趣的朋友一起看看吧
    2022-02-02
  • Spring中的ClassPathXmlApplicationContext源码详解

    Spring中的ClassPathXmlApplicationContext源码详解

    这篇文章主要介绍了Spring中的ClassPathXmlApplicationContext源码详解,ApplicationContext的主要实现类是ClassPathXmlApplicationContext和FileSystemXmlApplicationContext,前者默认从类路径加载配置文件,后者默认从文件系统中装载配置文件,需要的朋友可以参考下
    2023-12-12
  • 快速入手IntelliJ IDEA基本配置

    快速入手IntelliJ IDEA基本配置

    IntelliJ IDEA是java编程语言开发的集成环境,本篇主要介绍了对它的安装、配置maven仓库、调试方法、常用的插件推荐、快捷键大全与常用快捷键说明,感兴趣的朋友一起看看吧
    2021-10-10
  • HashMap 和 HashSet的区别

    HashMap 和 HashSet的区别

    本文主要介绍HashMap 和 HashSet的区别,这里整理了详细的资料来说名两者的区别,并说明如何使用该方法,有需要的小伙伴可以参考下
    2016-09-09

最新评论