0

0

java set什么意思

(*-*)浩

(*-*)浩

发布时间:2019-05-31 13:41:01

|

6002人浏览过

|

来源于php中文网

原创

java.util.set接口和java.util.list接口一样,同样继承自collection接口,它与collection接口中的方法基本一致,并没有对collection接口进行功能上的扩充,只是比collection接口更加严格了。与list接口不同的是,set接口中元素无序,并且都会以某种规则保证存入的元素不出现重复。

java set什么意思

Set集合有多个子类,这里我们介绍其中的java.util.HashSet、java.util.LinkedHashSet这两个集合。

特点:都会以某种规则保证存入的元素不出现重复,Set接口中元素无序

①元素不出现重复

立即学习Java免费学习笔记(深入)”;

②元素无序( 指存取无序)

哈希表:只要往哈希表中存储自定义对象,那么该自定义对象 所属的类 必须重写hashCode&equals方法

⑴HashSet集合

底层是通过HashMap实现的 底层new HashMap对象 ,只用了 key 并没有使用 value value指向统一地址 new Object()

API介绍:

java.util.HashSet是Set接口的一个实现类,它所存储的元素是不可重复的,并且元素都是无序的(即存取顺序不一致)。java.util.HashSet底层的实现其实是一个java.util.HashMap支持,HashSet是根据对象的哈希值来确定元素在集合中的存储位置,因此具有良好的存取和查找性能。保证元素唯一性的方式依赖于:hashCode与equals方法。

特点:

①元素不重复

②存取顺序不一致

③良好的存取和查找性能

④元素唯一性的方式依赖于:hashCode与equals方法

HashSet集合存储数据的结构(哈希表):

百度智能云·曦灵
百度智能云·曦灵

百度旗下的AI数字人平台

下载

在JDK1.8之前,哈希表底层采用数组+链表实现,即使用链表处理冲突,

同一hash值的链表都存储在一个链表里。但是当位于一个桶中的元素较多,

即hash值相等的元素较多时,通过key值依次查找的效率较低。

而JDK1.8中,哈希表存储采用数组+链表+红黑树实现,

当链表长度超过阈值(8)时,将链表转换为红黑树,这样大大减少了查找时间。

总而言之,JDK1.8引入红黑树大程度优化了HashMap的性能,

那么对于我们来讲保证HashSet集合元素的唯一,其实就是根据对象的

hashCode和equals方法来决定的。如果我们往集合中存放自定义的对象,

那么保证其唯一,就必须复写hashCode和equals方法建立属于当前对象的比较方式。

总结:1.8之前是通过 哈希表底层采用数组+链表实现

1.8中是通过哈希表存储采用数组+链表+红黑树实现(链表长度超过阈值(8)时,将链表转换为红黑树,这样大大减少了查找时间)保证元素其唯一,必须重写hashCode和equals方法建立属于当前对象的比较方式

HashSet存储自定义类型元素(重点):

给HashSet中存放自定义类型元素时,需要重写对象中的hashCode和equals方法,

建立自己的比较方式,才能保证HashSet集合中的对象唯一

⑵LinkedHashSet

HashSet保证元素唯一,可是元素存放进去是没有顺序的,那么我们要保证有序,怎么办呢,在HashSet下面有一个子类java.util.LinkedHashSet,它是链表和哈希表组合的一个数据存储结构。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

37

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

37

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

9

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.5万人学习

C# 教程
C# 教程

共94课时 | 6.7万人学习

Java 教程
Java 教程

共578课时 | 45.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号