Comparable接口与Comparator接口

目录

Comparable接口

使用Comparable接口进行people类按id排序

Comparator接口

使用Comparator接口打破people类原有规则按id排序


Comparable接口

Comparable接口是设计层面的排序 在使用treeset进行添加时使用的该接口排序规则

使用Comparable接口进行people类按id排序

public class match {
    public static void main(String[] args) {
       Solution666 s=new Solution666();
       people p1=new people(4);
       people p2=new people(3);
       people p3=new people(1);
       people p4=new people(9);
       TreeSet t=new TreeSet();
       t.add(p1);
        t.add(p2);
        t.add(p3);
        t.add(p4);
        System.out.println(t);
    }
}
class people implements Comparable<people>{
    int id;
    int name;
 public people(){

 }
    @Override
    public String toString() {
        return "people{" +
                "id=" + id +
                ", name=" + name +
                '}';
    }
    public people(int id) {
        this.id = id;
    }
    @Override
    public int compareTo(people o) {
        return this.id-o.id;
    }
}

排序规则从小到大

Comparator接口

在设计层面不满足自己需要的排序规则时,可使用自定义排序规则

使用Comparator接口打破people类原有规则按id排序

public class match {
    public static void main(String[] args) {
       Solution666 s=new Solution666();
       people p1=new people(4);
       people p2=new people(3);
       people p3=new people(1);
       people p4=new people(9);
       TreeSet t=new TreeSet(new Comparator<people>() {
           @Override
           public int compare(people o1, people o2) {
               return o2.id-o1.id;
           }
       });
       t.add(p1);
        t.add(p2);
        t.add(p3);
        t.add(p4);
        System.out.println(t);
    }
}
class people implements Comparable<people>{
    int id;
    int name;
 public people(){

 }
    @Override
    public String toString() {
        return "people{" +
                "id=" + id +
                ", name=" + name +
                '}';
    }
    public people(int id) {
        this.id = id;
    }
    @Override
    public int compareTo(people o) {
        return this.id-o.id;
    }
}

显而易见排序规则被改变

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

outlier--

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值