Java中的TreeSet源码解读

 更新时间:2023年09月13日 09:41:14   作者:风过无痕2018  
这篇文章主要介绍了Java中的TreeSet源码解读,TreeSet 是一个 有序集合,它扩展了 AbstractSet 类并实现了 NavigableSet 接口,对象根据其自然顺序以升序排序和存储,该 TreeSet 中使用 平衡树,更具体的一个 红黑树,需要的朋友可以参考下

TreeSet源码解读

特点: 可以排序

解读

  • 当我们使用无参构造器[new TreeSet();] 创建TreeSet时,仍然是无序的
  • 如果希望添加的元素,按照字符串大小来排序
    • 使用TreeSet 提供的一个构造器[ new TreeSet(new Comparator()],可以传入一个比较器(匿名内部类) 并指定排序规则

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

  • 构造器把传入的比较器对象,赋给 TreeSet的底层的 TreeMap的属性this.comparator
    public TreeMap(Comparator<? super K> comparator) {
           this.comparator = comparator;
    }
  • 在 调用 treeSet.add(“tom”), 在底层会执行到 [TreeMap类里的add()方法]
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源码解读内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java读取图片EXIF信息的方法

    Java读取图片EXIF信息的方法

    这篇文章主要介绍了Java读取图片EXIF信息的方法,较为详细的分析了图片EXIF信息的概念、功能及java读取EXIF信息的实现技巧,需要的朋友可以参考下
    2015-07-07
  • Java递归方法求5!的实现代码

    Java递归方法求5!的实现代码

    这篇文章主要介绍了Java递归方法求5!的实现代码,需要的朋友可以参考下
    2017-02-02
  • MyBatis在注解上使用动态SQL方式(@select使用if)

    MyBatis在注解上使用动态SQL方式(@select使用if)

    这篇文章主要介绍了MyBatis在注解上使用动态SQL方式(@select使用if),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Java synchronized底层实现原理以及锁优化

    Java synchronized底层实现原理以及锁优化

    Synchronized是Java中解决并发问题的一种最常用的方法,也是最简单的一种方法,下面这篇文章主要给大家介绍了关于Java synchronized底层实现原理以及锁优化的相关资料,需要的朋友可以参考下
    2022-02-02
  • 手写redis@Cacheable注解 支持过期时间设置方式

    手写redis@Cacheable注解 支持过期时间设置方式

    这篇文章主要介绍了手写redis@Cacheable注解 支持过期时间设置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • gateway网关接口请求的校验方式

    gateway网关接口请求的校验方式

    这篇文章主要介绍了gateway网关接口请求的校验方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • SpringBoot实现拦截器、过滤器、监听器过程解析

    SpringBoot实现拦截器、过滤器、监听器过程解析

    这篇文章主要介绍了SpringBoot实现拦截器、过滤器、监听器过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • 微服务和分布式的区别详解

    微服务和分布式的区别详解

    在本篇文章里小编给各位整理了关于微服务和分布式的区别以及相关知识点总结,有兴趣的朋友们学习下。
    2019-07-07
  • 一文掌握Spring 中 @Component 和 @Bean 区别(最新推荐)

    一文掌握Spring 中 @Component 和 @Bean 区别(最新推荐)

    ​@Component 用于标识一个普通的类,@Bean用于配置类里面,在方法上面声明和配置 Bean 对象,这篇文章主要介绍了Spring 中 @Component 和 @Bean 区别(最新推荐),需要的朋友可以参考下
    2024-04-04
  • idea2017建立jsp工程及tomcat配置教程

    idea2017建立jsp工程及tomcat配置教程

    本文通过图文并茂的形式给大家介绍了idea2017建立jsp工程及tomcat等配置的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-02-02

最新评论