自学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)
案例
明天将继续学习集合体系中的泛型。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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上本地化部署