java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > TreeSet源码解读

Java中的TreeSet源码解读

作者:风过无痕2018

这篇文章主要介绍了Java中的TreeSet源码解读,TreeSet 是一个 有序集合,它扩展了 AbstractSet 类并实现了 NavigableSet 接口,对象根据其自然顺序以升序排序和存储,该 TreeSet 中使用 平衡树,更具体的一个 红黑树,需要的朋友可以参考下

TreeSet源码解读

特点: 可以排序

解读

看看TreeMap(Comparator<? super K> comparator)的源码

    public TreeMap(Comparator<? super K> comparator) {
           this.comparator = comparator;
    }
Comparator<? super K> cpr = comparator; //把之前TreeMap里的比较器赋给cpr
    if (cpr != null) {//cpr 就是我们的匿名内部类(对象)
       do {
           parent = t;
           cmp = cpr.compare(key, t.key); //动态绑定到我们的匿名内部类(对象)compare
           if (cmp < 0)
               t = t.left;
           else if (cmp > 0)
               t = t.right;
           else //如果相等,即返回0,这个Key就没有加入
               return t.setValue(value);
       } while (t != null);
   }

实际应用

    TreeSet treeSet = new TreeSet(new Comparator() {
        @Override
        public int compare(Object o1, Object o2) {
            //下面 调用String的 compareTo方法进行字符串大小比较
            //return ((String) o2).compareTo((String) o1);
            //如果老韩要求加入的元素,按照长度大小排序
            return ((String) o1).length() - ((String) o2).length();
        }
    });

到此这篇关于Java中的TreeSet源码解读的文章就介绍到这了,更多相关TreeSet源码解读内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文