HashSet和TreeSet的区别

不同

  • 底层
  • HashSet
    • HashSet底层使用的哈希表,根据对象的hashCode()值计算存储位置,比较hashCode()值,equals()方法,进行比较是否相同.由于在HashSet底层是使用HashMap实现,而在jdk1.8中HashMap在其链表超过8个时,将会将链表转换成红黑树,进行优化时间复杂度.但是其还是使用哈希表进行判断存储位置,依然是无序的.
    • HashSet可以存null,而碰到的异常是从自动拆装箱造成的
  • TreeSet
    • TreeSet底层数据结构是红黑树,按照第一个为为根元素,再根据其是自然排序实现Comparable接口,重写compareTo(T o)方法或重写Comparator的compare(T o1,T o2)方法比较与根元素比较大小,小的放左边大的放右边,如果左边或者右边存在元素,则进行比较规则依然是小的放左边大的放右边,完成红黑树的建立,
    • 当进行遍历时从树的最左侧叶节点开始遍历,然后是父节点,然后是相邻的兄弟节点,依次遍历完毕.
    • TreeSet的红黑树的遍历是中序遍历
    • TreeSet不能存储null,主要是Comparable与Comparator的compareTo()方法与compare()方法报空指针
  • 造成的结果就是TreeSet是有序的而HashSet是无序的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

嘿嘿嘿1212

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

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

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

打赏作者

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

抵扣说明:

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

余额充值