Java学习笔记 --- TreeSet和TreeMap

一、TreeSet源码解读

package com.javase.set_;

import java.util.Comparator;
import java.util.TreeSet;

public class TreeSet01 {
    public static void main(String[] args) {
        //1. 当我们使用无参构造器,创建TreeSet时,仍然是无序的
        //2. 希望添加的元素,按照字符串大小来排序
        //3. 使用TreeSet 提供的一个构造器,可以传入一个比较器(匿名内部类) 并指定排序规则

        //TreeSet treeSet = new TreeSet();
        TreeSet treeSet = new TreeSet(new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                //下面调用 String 的 compareTo 方法比较字符串大小
                return ((String) o1).compareTo((String) o2);
            }
        });
        //添加数据
        treeSet.add("jack");
        treeSet.add("tom");
        treeSet.add("sp");
        treeSet.add("a");

        System.out.println(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;
                    //动态绑定到我们的匿名内部类对象 comparator
                    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);
            }
         */
    }
}

二、TreeMap源码解读

import java.util.Comparator;
import java.util.TreeMap;

public class TreeMap01 {
    public static void main(String[] args) {
        //1. 当我们使用无参构造器,创建TreeMap时,仍然是无序的
        //2. 希望添加的元素,按照字符串大小来排序
        //3. 使用TreeMap 提供的一个构造器,可以传入一个比较器(匿名内部类) 并指定排序规则
        //TreeMap treeMap = new TreeMap();
        TreeMap treeMap = new TreeMap(new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                return ((String) o1).compareTo((String) o2);
            }
        });

        treeMap.put("jack", "张三");
        treeMap.put("tom", "李四");
        treeMap.put("smith", "老六");
        treeMap.put("kristina", "铁蛋");

        System.out.println(treeMap);

        //源码解读
        /*
        1. 构造器 把传入的比较器对象,赋给了 TreeMap 的属性 this.comparator
           public TreeMap(Comparator<? super K> comparator) {
                  this.comparator = comparator;
           }
        2. 在 调用 put 方法时
           (1)第一次添加,把k-v封装到Entry对象,放入root
           (2)后续添加时 底层会执行到
           if (cpr != null) { //cpr 就是我们的匿名内部类(对象)
                do { //遍历所有key 给当前的key找到适当的位置
                    parent = t;
                    //动态绑定到我们的匿名内部类对象 comparator
                    cmp = cpr.compare(key, t.key);
                    if (cmp < 0)
                        t = t.left;
                    else if (cmp > 0)
                        t = t.right;
                    else //如果遍历过程中 key相等 即等于0 这个key就不加入
                        return t.setValue(value);
                } while (t != null);
            }
         */
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值