Java中的LinkedHashSet源码解读

 更新时间:2023年09月04日 09:48:36   作者:伊颦伊笑  
这篇文章主要介绍了Java中的LinkedHashSet源码解读,LinkedHashSet 是 Java 中的一个集合类,它是 HashSet 的子类,并实现了 Set 接口,与 HashSet 不同的是,LinkedHashSet 保留了元素插入的顺序,并且具有 HashSet 的快速查找特性,需要的朋友可以参考下

LinkedHashSet

在这里插入图片描述

基本介绍

  1. LinkedHashSet 是 HashSet 的子类
  2. LinkedHashSet 底层是一个 LinkedHashMap,底层维护了一个数组+双向链表
  3. LinkedHashSet 根据元素的 hashCode 值来决定元素的存储位置,同时使用链表维护元素的次序(图),这使得元素看起来是以插入顺序保存的。
  4. LinkedHashSet 不允许添重复元素

说明

在这里插入图片描述

  • 在 LinkedHastSet 中维护了一个 hash 表和双向链表(LinkedHashSet 有head和tail)
  • 每一个节点有 pre 和 next 属性,这样可以形成双向链表
  • 在添加一个元素时,先求hash值,再求索引,确定该元素在hashtable 的位置,然后将添加的元素加入到双向链表(如果已经存在,不添加【原则和 hashset 一样】)
tail.next = newElement//简单指定
newElement.pre = tail
tail = newEelment;
  • 这样的话,我们遍历 LinkedHashSet 也能确保插入顺序和遍历顺序一致

LinkedHashSet 源码解读

package collection_;
import java.util.LinkedHashSet;
import java.util.Set;
/**
 * @Author: Gin
 * @Description:
 * @Modified By: Gin
 * @Date: Created in 11:12 2021/9/22
 */
public class LinkedHashSetSource {
    public static void main(String[] args) {
        // 分析 LinkedHashSet 的底层机制
        Set set = new LinkedHashSet();
        set.add(new String("AAA"));
        set.add(456);
        set.add(456);
        set.add(new Customer("Tom", 1));
        set.add(123);
        set.add("Gin");
        System.out.println("set = " + set);
        // 解读:
        // 1. LinkedHashSet 中元素的取出顺序和加入顺序一致
        // 2. LinkedHashSet(HashSet的子类) 底层其实是 LinkedHashMap(HashMap的子类)
        // 3. LinkedHashSet 底层结构(table数组 + 双向链表)
        // 4. 第一次添加数据,将 table数组 直接扩容至 16 个空间大小
        // 5. table数组的类型为 HashMap$Node[]
        // 6. table数组中存放数据的结点类型是 LinkedHashMap$Entry
        /*
            LinkedHashMap 的静态内部类 Entry 继承自 HashMap 的静态内部类 Node
            static class Entry<K,V> extends HashMap.Node<K,V> {
                Entry<K,V> before, after; // before, after 用来形成双向链表
                Entry(int hash, K key, V value, Node<K,V> next) {
                    super(hash, key, value, next);
                }
            }
         */
    }
}
class Customer{
    private String name;
    private int no;
    public Customer(String name, int no) {
        this.name = name;
        this.no = no;
    }
}

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

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

相关文章

  • centos上安装配置java WEB环境

    centos上安装配置java WEB环境

    前提是centos6.3系统已经安装好,在这里以64位系统为例,下面是jdk,tomcat,mysql下载安装步骤,有需要的小伙伴可以参考下
    2016-10-10
  • Java Comparator比较器实例解析

    Java Comparator比较器实例解析

    这篇文章主要介绍了Java Comparator比较器实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • 详解如何使用XML配置来定义和管理Spring Bean

    详解如何使用XML配置来定义和管理Spring Bean

    XML 配置文件是 Spring 中传统的 Bean 配置方式,通过定义 XML 元素来描述 Bean 及其依赖关系,在 Spring 框架中,Bean 是由 Spring IoC(控制反转)容器管理的对象,本文将详细介绍如何使用 XML 配置来定义和管理 Spring Bean,需要的朋友可以参考下
    2024-06-06
  • Mybatis逆向工程实现连接MySQL数据库

    Mybatis逆向工程实现连接MySQL数据库

    本文主要介绍了Mybatis逆向工程实现连接MySQL数据库,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • springboot中不能获取post请求参数的解决方法

    springboot中不能获取post请求参数的解决方法

    这篇文章主要介绍了springboot中不能获取post请求参数的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Java中的Pair详细

    Java中的Pair详细

    这篇文章主要介绍Java中的很有意思的Pair,下面文章会以Pair用法展开,感兴趣的小伙伴可以参考下面文章的具体内容
    2021-10-10
  • SpringBoot整合H2数据库的操作方法

    SpringBoot整合H2数据库的操作方法

    H2是一个Java语言编写的嵌入式数据库,它不受平台的限制,同时H2提供了一个十分方便的web控制台,用于操作和管理数据库内容,本文介绍SpringBoot整合H2数据库的方法,感兴趣的朋友一起看看吧
    2024-01-01
  • springboot扫码登录的简单实现

    springboot扫码登录的简单实现

    本文主要介绍基于SpringBoot + Vue + Android实现的扫码登录,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • Java枚举学习之定义和基本特性详解

    Java枚举学习之定义和基本特性详解

    枚举是JAVA 5.0后增加的一个重要类型。可以用来表示一组取值范围固定的变量。本文将通过示例为大家详细讲解枚举的定义和基本特性,感兴趣的可以了解一下
    2022-08-08
  • Spring boot集成spring session实现session共享的方法

    Spring boot集成spring session实现session共享的方法

    这篇文章主要介绍了Spring boot集成spring session实现session共享的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-06-06

最新评论