TreeMap实现自然排序与定制排序

在Java中,如果我们想要实现对我们类中的对象按照一定规则进行比较,就要在类中实现Compare类并重写compareTo方法(自然排序)。

首先我们要新建一个类,在这个类中必须实现Comparable接口,并重写这个接口的compareTo方法

public class User implements Comparable{
    private String name;
    private int age;

    public User() {
    }

    public User(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        User user = (User) o;
        return age == user.age &&
                Objects.equals(name, user.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }

    //按照姓名从大到小排列,年龄从小到大排列
    @Override
    public int compareTo(Object o) {
        if (o instanceof User){
            User user = (User) o;
            int compare = -this.name.compareTo(user.name); //前面加负号就是降序排列
            if (compare != 0){
                return compare;
            } else {
                return Integer.compare(this.age,user.age); //如果姓名一样就比较年龄升序排列
            }
        } else {
            throw new RuntimeException("输入的类型不匹配");
        }
    }
}

测试如下:

public class TreeMapeTest {
    //自然排序
    @Test
    public void test(){
        TreeMap map = new TreeMap();

        User u1 = new User("Tom",11);
        User u2 = new User("Team",30);
        User u3 = new User("John",23);
        User u4 = new User("Jerry",18);

        map.put(u1,11);
        map.put(u2,11);
        map.put(u3,22);
        map.put(u4,33);

        Set entrySet = map.entrySet();
        Iterator iterator = entrySet.iterator();
        while (iterator.hasNext()){
            Object obj = iterator.next();
            Map.Entry entry = (Map.Entry) obj;
            System.out.println(entry.getKey() + "------>" + entry.getValue());
        }
    }

    //定制排序
    @Test
    public void test2(){
        TreeMap map = new TreeMap(new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                if (o1 instanceof User && o2 instanceof User){
                    User u1 = (User) o1;
                    User u2 = (User) o2;
                    return Integer.compare(u1.getAge(),u2.getAge());
                } else {
                    throw new RuntimeException("输入的类型不匹配");
                }
            }
        });

        User u1 = new User("Tom",11);
        User u2 = new User("Team",30);
        User u3 = new User("John",23);
        User u4 = new User("Jerry",18);

        map.put(u1,11);
        map.put(u2,11);
        map.put(u3,22);
        map.put(u4,33);

        Set entrySet = map.entrySet();
        Iterator iterator = entrySet.iterator();
        while (iterator.hasNext()){
            Object obj = iterator.next();
            Map.Entry entry = (Map.Entry) obj;
            System.out.println(entry.getKey() + "------>" + entry.getValue());
        }
    }
}

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值