当前位置: 首页 > wzjs >正文

我看别人做系统就直接网站下载软件霸州做网站

我看别人做系统就直接网站下载软件,霸州做网站,长沙网页设计哪个公司好,百度站长怎样添加网站Java Set系列集合详解:HashSet、LinkedHashSet、TreeSet底层原理与使用场景 一、Set系列集合概述 1. 核心特点 无序性:存取顺序不一致(LinkedHashSet除外)。唯一性:元素不重复。无索引:无法通过索引直接访…

Java Set系列集合详解:HashSet、LinkedHashSet、TreeSet底层原理与使用场景


一、Set系列集合概述

1. 核心特点

  • 无序性:存取顺序不一致(LinkedHashSet除外)。
  • 唯一性:元素不重复。
  • 无索引:无法通过索引直接访问元素,不能使用普通for循环遍历。

2. 常见实现类

实现类特点底层数据结构
HashSet无序、唯一、无索引哈希表(数组+链表/红黑树)
LinkedHashSet有序(存取顺序一致)、唯一哈希表+双向链表
TreeSet可排序(自然或自定义)、唯一红黑树

二、Set接口常用方法

Set继承自Collection接口,常用方法如下:

方法说明
boolean add(E e)添加元素,成功返回true
void clear()清空集合
boolean remove(E e)删除指定元素
`boolean contains(Object)判断是否包含元素
int size()返回集合元素个数

三、各实现类详解

1. HashSet

底层原理
  • JDK8前:数组 + 链表。
  • JDK8后:数组 + 链表 + 红黑树(链表长度≥8且数组长度≥64时触发转换)。
  • 哈希值计算:通过重写hashCode()equals()保证元素唯一性。
扩容机制
  • 默认初始容量:16。
  • 加载因子:0.75(当元素数量达到容量的75%时触发扩容)。
代码示例
Set<String> set = new HashSet<>();
set.add("A");
set.add("A"); // 添加失败
System.out.println(set); // 输出无序,如 [A, B]

2. LinkedHashSet

核心特点
  • 继承自HashSet,通过双向链表维护插入顺序。
  • 性能略低于HashSet,但遍历效率更高。
代码示例
LinkedHashSet<String> linkedSet = new LinkedHashSet<>();
linkedSet.add("B");
linkedSet.add("A");
System.out.println(linkedSet); // 输出顺序固定为 [B, A]

3. TreeSet

排序规则
  • 自然排序:元素需实现Comparable接口,重写compareTo()
  • 比较器排序:创建TreeSet时传入Comparator自定义规则。
代码示例
// 自然排序(按年龄升序)
TreeSet<Student> treeSet = new TreeSet<>();
treeSet.add(new Student("Tom", 20));
treeSet.add(new Student("Alice", 18));
// 输出按年龄排序:Alice(18) → Tom(20)

四、补充知识点

1. 线程安全性

  • HashSetTreeSetLinkedHashSet非线程安全
  • 解决方案:使用Collections.synchronizedSet()包装。
Set<String> syncSet = Collections.synchronizedSet(new HashSet<>());

2. 哈希冲突解决策略

  • 链地址法(HashSet采用):冲突元素以链表形式存储。
  • 开放寻址法:线性探测或二次探测。

3. 红黑树简介

  • 一种自平衡二叉查找树,保证插入、删除、查找的时间复杂度为O(log n)
  • 特性:节点颜色交替、根节点为黑、叶子节点为黑、任意路径黑节点数相同。

4. 性能对比

操作HashSetLinkedHashSetTreeSet
插入O(1)O(1)O(log n)
删除O(1)O(1)O(log n)
查询O(1)O(1)O(log n)
有序性插入顺序自然/自定义

五、应用场景总结

场景推荐集合
去重且无需顺序HashSet
去重且保留插入顺序LinkedHashSet
去重且需排序TreeSet
高频查询HashSet
需要线程安全Collections.synchronizedSet()

六、常见面试题

  1. HashSet如何保证元素唯一?
    通过hashCode()equals()方法:先比较哈希值,再通过equals判断内容是否相同。

  2. TreeSet两种排序方式如何选择?

    • 默认使用自然排序(需实现Comparable)。
    • 若类无法修改或需多规则排序,使用Comparator
  3. HashSet和HashMap的关系?
    HashSet底层基于HashMap实现,元素存储为HashMap的键(值固定为PRESENT占位对象)。


关注博主,获取更多Java集合框架深度解析!

http://www.dtcms.com/wzjs/572316.html

相关文章:

  • 哪些网站是做婴童辅食招商的广告设计公司需要资质吗
  • 网站建设160页答案广州制作网站企业
  • 十大免费货源网站免费版本wordpress 图片循环
  • 女人做春梦视频网站ai域名注册
  • 做衣服外贸用什么网站好怎样学习网站建设
  • 天津响应式网站设计wordpress做社交网站吗
  • 晋城建设局官方网站在小说网站做编辑怎么找
  • 番禺网站开发报价广告设计策划
  • 上海网站设计公司推荐亿企邦公司装修效果图 办公室
  • 天津企业网站设计制作广告公司品牌营销推广
  • 营口网站优化外贸网站建设 双语网站建设
  • 如何选择网站开发无线网络建设方案
  • 网站软文得特点烟台建设协会网站
  • 购物网站设计目的厦门网站建设680元
  • 网站查询域名ip查询cms 做网站模板
  • 基层建设被哪些网站全文收录政务网站的建设原则
  • 品牌推广多少钱哈尔滨的网络优化能做么
  • 即刻搜索收录网站做直播网站找哪个
  • 个人想建个网站怎么弄免费ps素材图片大全
  • 泰安高端网站设计建设淘宝官网首页进入
  • 网站建设有什么优点网站建设业务怎么做
  • 做html网站模板怎么用pf做网站
  • 建设网站目录wordpress登入后台没反应
  • 小程序开发者工具石家庄谷歌seo
  • 网站开发的缓存技术广州越秀区儿童医院
  • 建设厅企业锁在哪个网站登录wordpress国外主题安装
  • 景区网站建设策划书专业模板建站公司
  • 汽车网站大全汽车网黄页88和58那个推广好
  • 模版网站可以做seo吗公司个人怎么制作网站
  • 网站建设与管理实训报告网站建设的服务和质量