Set集合

Set集合
(1)Set集合的特点 :无序,唯一
(2)HashSet集合
A:
底层数据结构是哈希表(是一个元素为链表的数组)
B:
哈希表底层依赖两个方法: hashCode()和equals() 执行顺序首先比较哈希值是否相同
相同: 继续执行equals()方法
返回true:元素重复了,不添加
返回false:直接把元素添加到集合
不同:就直接把元素添加到集合
C:如何保证元素是唯一性的呢?
由hashCode()和equals()保证的
D:开发的时候,代码非常的简单,自动生成即可。
E:HashSet存储字符串并遍历
F:HashSet存储自定义对象并遍历(对象的成员变量值相同即为同一个元素)
(3)TreeSet集合
A:底层数据结构是红黑树(是一个自平衡的二叉树)
B: 保证元素的排序方式
a:自然排序(元素具备比较性)[是根据集合元素的大小,TreeSet将它们升序排列让元素所属的类实现 Comparator接口
b:定制排序(集合具有比较性)[在创建TreeSet集合对象的时,提供一个Comparator对象与该TreeSet集合关联,由该Comparator对象负责集合元素的排序逻辑] 让集合构造方法接收+Comparator的实现类对象
各Set实现类的性能分析
到底该如何选择HashSet和TreeSet呢?
HashSet的性能总是比TreeSet好(特别是最常用的添加,查询元素等操作),因为TreeSet需要额外的红黑树算法来维护集合元素的次序。
只有当需要一个保持排序的Set时,才应该使用TreeSet,否则都应该使用HashSet。
HashSet还有一个子类:LinkedHashSet,对于普通的插入,删除操作,LinkedHashSet比HashSet要稍微慢一点,这是由于维护链表所带来的额外开销造成的, 但由于有了链表,遍历LinkedHashSet会更快 EnumSet是所有Set实现类中性能最好的,但它只能保存同一个枚举类的枚举值作为集合元素
Set的三个实现类都是线程不安全的,如果由多个线程同时访问一个Set集合,并且有超过一个线程修改了该Set集合,则必须手动保证该Set集合的同步性。
通常可以通过Collections工具类的synchronizedSortedSet方法来“包装”该Set集合。此操作最好在创建时就进行,以防止对Set集合的意外非同步访问

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值