随笔 - 217  文章 - 4  评论 - 4  阅读 - 23587

自学Java第三十课

HashSet特点

  ①底层数据为哈希表;②对集合的迭代顺序不做保证,使用迭代器和增强for遍历。

哈希表

  本质为数组,默认长度为16

HashSet保证元素唯一性

  调用hashCode()获取哈希值

        ↓

  计算对象存储位置

        ↓

  判断该位置是否有元素                    →没有    →

                            ↓

        ↓有                

  遍历所有元素,和新元素比较哈希值是否相同→不相同    元素存储位置

        ↓相同                  ↑

  调用equals(),比较内容             false                        →

        ↓true

  元素重复,不存储

 

 

LinkedHashSet特点

  ①哈希表和链表实现的set接口,具有可预测的迭代顺序;

  ②由链表保证元素有序,也就是元素的存储和取出一致;

  ③哈希表保证元素唯一性

 

 TreeSet特点

  ①元素有序,元素按一定顺序进行排序,具体方式取决于构造方法

    TreeSet()根据元素的自然顺序进行排序

    TreeSet(comparator comparator)根据指定的比较器排序

  ②不能使用for循环

  ③无重复元素,Set之下

<>里面使用的是数据类型中的包装类

 

Comparable自然排序

  ①用TreeSet集合存储对象,无参构造方法使用的是自然排序排列元素

  ②自然排序,让所有元素所属的类实现comparable接口,重写compareTo(T o)方法

  ③重写方法时,注意主要条件和次要条件

 

 

 

 比较器使用

  ①用TreeSet集合存储自定义对象,带参构造使用比较器排列

  ②比较器排列,让集合构造方法接受comparator实现对象,重写compare(T o1,T o2)

 

 案例

 

 明天将继续学习集合体系中的泛型。

 

posted on   跨越&尘世  阅读(22)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示