Java中的Set集合不允许存储重复元素的原理详解

 更新时间:2023年09月18日 10:25:19   作者:秃头不秃头农  
这篇文章主要介绍了Java中的Set集合不允许存储重复元素的原理详解,我们之前使用Set集合的时候发现,Set集合的特点是不允许存储重复元素,这是为什么呢,下面我们一起来研究一下,需要的朋友可以参考下

Set集合不允许存储重复元素的原理详解

代码如下(示例):

//创建hashset集合对象
        HashSet<String> set = new HashSet<>();
        String s1=new String("abc");
        String s2=new String("abc");
        set.add(s1);
        set.add(s2);
        set.add("重地");
        set.add("通话");//两个特殊的字符串
        set.add("abc");
        System.out.println(set);

我们可以看到,我向set集合中存储了三次abc和两个特殊字符串,我们可以看到打印结果:

在这里插入图片描述

我们可以发现,集合中只有重地,通话,abc。为什么会出现这样的结果呢。

第一步:我们创建了一个hashset集合。

//创建hashset集合对象
        HashSet<String> set = new HashSet<>();

我们一定是在堆内存中开辟一块空间。上一篇文章中我们说到hashset的结构是:哈希表:数组+链表/红黑树。我们可以看到:

在这里插入图片描述

注意:set集合在调用add方法时,会调用元素的hashcode和equals方法,判断元素是否重复。 首先,我们向集合中存储的第一个元素是s1

        set.add(s1);

add方法回调用s1.hashCode()方法,计算字符串abc的哈希值(96354)。就会在集合中找有没有96354这个哈希值的元素。发现没有,就会将元素abc存储到集合中去。

在这里插入图片描述

当开始存储存储s2时,add方法回调用s2.hashCode()方法,计算字符串abc的哈希值(96354)。就会在集合中找有没有96354这个哈希值的元素。发现有,注意哈希值一样就会发生哈希冲突。s2会调用equals方法和哈希值相同的元素进行比较:s2.equals(s1),equals方法返回ture,认定两个元素相同,就不会把s2存储到集合中。

之后我们就要存储字符串重地:

        set.add("重地");

add方法回调用重地.hashCode()方法,计算字符串重地的哈希值(1179395)。就会在集合中找有没有1179395这个哈希值的元素。发现没有,就会将元素重地存储到集合中去。

在这里插入图片描述

接下来我们就该存储通话。add方法回调用通话.hashCode()方法,计算字符串通话的哈希值(1179395)。就会在集合中找有没有1179395这个哈希值的元素。发现有,就会调用equals方法进行比较:”通话“.equals(“重地”),返回false,认定两个元素不相同,所以会将元素存储在1179395同样的位置上。

在这里插入图片描述

这就是set元素存储元素不重复的元素的原理。但是这有一个前提,存储元素必须重写hashcode和eqluas方法,保证元素不重复。

到此这篇关于Java中的Set集合不允许存储重复元素的原理详解的文章就介绍到这了,更多相关Set集合底层原理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 简单的java读取文件示例分享

    简单的java读取文件示例分享

    这篇文章主要介绍了java读取txt文件内容,示例很简单,代码里有注释,大家直接看代码吧
    2014-01-01
  • springcloud初体验(真香)

    springcloud初体验(真香)

    这篇文章主要介绍了springcloud初体验(真香),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • java环境搭建教程

    java环境搭建教程

    这篇文章主要为大家详细介绍了java环境的搭建教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • SpringBoot集成Spring security JWT实现接口权限认证

    SpringBoot集成Spring security JWT实现接口权限认证

    这篇文章主要介绍了SpringBoot集成Spring security JWT实现接口权限认证,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • swing中Tree与滚动条用法实例分析

    swing中Tree与滚动条用法实例分析

    这篇文章主要介绍了swing中Tree与滚动条用法,以实例形式分析了java基于swing实现图形界面的使用技巧,需要的朋友可以参考下
    2015-09-09
  • spring中@Reference注入为空的解决方法

    spring中@Reference注入为空的解决方法

    今天上线遇到了问题,所以抽空记录一下,本文主要介绍了spring中@Reference注入为空的解决方法,需要的朋友们下面随着小编来一起学习学习吧
    2021-06-06
  • Java入门教程--带包的类如何编译与运行

    Java入门教程--带包的类如何编译与运行

    我们一般都是通过IDE(如Eclipse、Intellij Idea,STS等)来开发,调试java项目。在不借助IDE的情况下,如何编译、运行Java程序。打包编译时,会自动创建包目录,不需要自己新建包名文件夹。
    2022-12-12
  • 基于多线程中join()的用法实例讲解

    基于多线程中join()的用法实例讲解

    下面小编就为大家带来一篇基于多线程中join()的用法实例讲解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • MybatisPlus中的多表条件排序查询

    MybatisPlus中的多表条件排序查询

    这篇文章主要介绍了MybatisPlus中的多表条件排序查询,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • java maven进阶教学

    java maven进阶教学

    这篇文章主要介绍了Maven进阶教程的相关资料,文中讲解非常细致,帮助大家开始学习maven,感兴趣的朋友可以了解下,希望能够给你带来帮助
    2021-08-08

最新评论