【Java学习笔记】Set 接口实现类-TreeSet

一、如何排序

当我们使用无参构造器,创建 TreeSet 时,仍然是无序的
用 TreeSet 提供的一个构造器,可以传入一个比较器(匿名内部类)指定排序规则

二、源码解读

/*
1. 构造器把传入的比较器对象,赋给了 TreeSet 的底层的 TreeMap 的属性 this.comparator
     public TreeMap(Comparator<? super K> comparator) {
      this.comparator = comparator;
      }
2. 在 调用 treeSet.add("tom"), 在底层会执行到
     if (cpr != null) {//cpr 就是我们的匿名内部类(对象)
      do {
      parent = t;
//动态绑定到我们的匿名内部类(对象)compare
     cmp = cpr.compare(key, t.key);
     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();
  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();
}
});
//添加数据. treeSet.add("jack");、
treeSet.add("tom");//3
treeSet.add("sp");
treeSet.add("a");
treeSet.add("abc");//3
System.out.println("treeSet=" + treeSet);
}
}

比较长度时:长度相同不添加
比较大小时:大小相同不添加

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值