Java深入了解TreeSet

1.什么是TreeSet?
Java中的TreeSet是Set的一个子类,TreeSet集合是用来对象元素进行排序的,同样他也可以保证元素的唯一。
那TreeSet为什么能保证元素唯一,它是怎样排序的呢?先看一段代码:
Java深入了解TreeSet在这里插入图片描述
Java深入了解TreeSet
为什么返回0,只会存一个元素,返回-1会倒序存储,返回1会怎么存就怎么取呢?原因在于TreeSet底层其实是一个二叉树机构(解释:这里的二叉树是左边的元素小于右边的元素),且每插入一个新元素(第一个除外)都会调用compareTo()方法去和上一个插入的元素作比较,并按二叉树的结构进行排列。

  1. 如果将compareTo()返回值写死为0,元素值每次比较,都认为是相同的元素,这时就不再向TreeSet中插入除第一个外的新元素。所以TreeSet中就只存在插入的第一个元素。
  2. 如果将compareTo()返回值写死为1,元素值每次比较,都认为新插入的元素比上一个元素大,于是二叉树存储时,会存在根的右侧,读取时就是正序排列的。
  3. 如果将compareTo()返回值写死为-1,元素值每次比较,都认为新插入的元素比上一个元素小,于是二叉树存储时,会存在根的左侧,读取时就是倒序序排列的。
    解释:以上的说法都是没有重写compareTo()的,是对原compareTo()方法的解读

Java深入了解TreeSet
Java深入了解TreeSet
下图是自定义一个比较器(实现Comparator接口)
Java深入了解TreeSet
Java深入了解TreeSet
Java深入了解TreeSet