TreeSet源码解读

TreeSet源码解读

特点: 可以排序

解读

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

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

  1. 构造器把传入的比较器对象,赋给 TreeSet的底层的 TreeMap的属性this.comparator
    public TreeMap(Comparator<? super K> comparator) {
           this.comparator = comparator;
    }
  1. 在 调用 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();
        }
    });
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值