java数据结构Set与HashSet

1.Set接口

不包含重复元素的Collection。

什么是重复元素呢?
就是set中 不包含满足 e1.equals(e2) 的元素对 e1 和 e2,并且最多包含一个 null 元素。

2.SortedSet接口

(1)SortedSet接口是Set的一个子接口

(2)SortedSet继承自Set接口

(3)具有Set的所有功能,是一个Sorted类型的Set

(4)提供关于元素的总体排序的Set

3.HashSet类

(1)实现Set接口
(2)由哈希表支持
(3)HashSet类是为快速查找而设计的Set

(4)迭代时间与HashSet大小和底层HashMap容量的和成比例

4.LinkedHashSet类

(1)实现Set接口
(2)是HashSet类的子类
(3)可预知迭代顺序的链接哈希Set
(4)LinkedHashSet按照插入顺序保存对象,同时还保存了HashSet的查询速度。

(5)迭代时间与Set大小成正比例,与容量无关

(6具有HashSet的查询速度,且内部使用链表维护元素的顺序)

5.TreeSet类

TreeSet也不能存放重复对象,但是TreeSet会自动排序。

如果存放的对象不能排序则会报错。

所以存放的对象必须指定排序规则。

排序规则包括自然排序和自定义排序。

(1)自然排序:

TreeSet要添加哪个对象就在哪个对象类上面实现java.lang.Comparable接口

并且重写comparaTo()方法。

返回0则表示是同一个对象,否则为不同对象。

(2)自定义排序:

 建立一个第三方类并实现java.util.Comparator接口。

并重写方法。

定义集合形式为TreeSet ts = new TreeSet(new 第三方类());

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北顾丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值