Set接口(HashSet,LinkedHashSet,TreeSet)

HashSet:

·采用散列表(哈希表),基于HashMap来实现,map是整个HashSet的核心

·线程不同步

·特点:元素无序和不重复

·保证元素唯一性:通过元素的hashCode()和equals()方法。

 调用add()方法向集合中存入对象的时候,首先通过hashCode方法计算该对象的hash值,然后比较与原有对象的hash值是否有   一样的,如果没有一样的hash值就直接存入;如果存在与之相同的hash值,则需要继续比较这两个对象是否相同,使用equals   方法进行判断。

  总结:1)equals()相等的两个对象他们的hashCode()肯定相等,也就是用equal()对比是绝对可靠的。

            2)hashCode()相等的两个对象他们的equals()不一定相等,也就是hashCode()不是绝对可靠的。

·集合元素可以为null,但只能放入一个null



LinkedHashSet:

·底层是链表实现的,是set集合中唯一一个能保证怎么存就怎么取的集合对象。

·LinkedHashSet 继承于 HashSet,并且其内部是通过 LinkedHashMap 来实现的。因为是HashSet的子类,所以也是保证元   素唯一的,与HashSet的原理一样。

·如果需要迭代的顺序为插入顺序或者访问顺序,则首先考虑LinkedHashSet。



TreeSet:

·底层的数据结构是二叉树

·基于TreeMap实现。

·有序的

·非线程安全的。

·不支持快速随机遍历,只能通过迭代器进行遍历

·TreeSet排序的两种方式:自然排序比较器排序

自然排序:需要被排序的类实现Comparable<T>接口;重写其中的 comparaTo方法。

              TreeSet类的add()方法中会把存入的对象提升为Comparable类型,调用对象的compareTo()方法和集合中的对象比较,根据compareTo()                                    方法返回的结果进行存储。

              comparaTo方法返回-1,表示放在红黑树的左边,即逆序输出;

              comparaTo方法返回1,表示放在红黑树的右边,即顺序输出;

              comparaTo方法返回0,表示元素相同,仅存放第一个元素。

比较器排序:需要一个新的类实现Comparator<T>接口,重写其中的Compare 方法。

                 创建TreeSet的时候可以制定 一个Comparator,如果传入了Comparator的子类对象, 那么TreeSet就会按照比较器中的顺序排序,add()方法内部                       会自动调用Comparator接口中compare()方法排序,调用的对象是compare方法的第一个参数,集合中的对象是compare方法的第二个参数。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值