comparable 和 comparator

本文详细解释了Java中Comparable与Comparator接口的区别与应用。通过具体的User类排序实例,展示了如何使用这两种方式实现对象的排序,包括类的设计改造和自定义比较器。

comparable 字面意思就是“可以比较的” 因此实现了这个接口的类是可以自动比较的(通过sort()方法),不需要另外构造比较器。  类中默认的比较方法是compareTo()方法

comparator 字面意思是“比较器”,实现了这个接口的类就相当于一个比较器,这个比较器是自己定义的,你可以通过里面的compare方法自己定义比较逻辑。 比如当我需要用这种“比较器”比较一些放在list中的对象时,可以这样调用: sort(list<T>, comparator)。


下面我通过一个具体例子来说明两者的使用:

假设现在有个User类,有id,age字段。 我需要按age字段对User类排序

public class User {

  private String id;
  private int age;

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

  public int getAge() {
    return age;
  }

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

  public String getId() {
    return id;
  }

  public void setId(String id) {
    this.id = id;
  }

}

使用comparable方式来实现的话,需要对User类进行改造:

Comparable接口强行对实现它的每个类的对象进行整体排序。排序中使用的比较规则是CompareTo()方法


import java.util.Arrays;

public class User implements Comparable {

  private String id;
  private int age;

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

  public int getAge() {
    return age;
  }

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

  public String getId() {
    return id;
  }

  public void setId(String id) {
    this.id = id;
  }
  //实现compareTo方法
  public int compareTo(Object o) {
    return this.age - ((User) o).getAge();
  }

  /**
   * 测试方法
   */
  public static void main(String[] args) {
    User[] users = new User[] { new User("a", 30), new User("b", 20) };
    Arrays.sort(users);//因为user实现了Comparable接口,所以可以直接比较,调用compareTo()做为比较规则
    for (int i = 0; i < users.length; i++) {
      User user = users[i];
      System.out.println(user.getId() + " " + user.getAge());
    }
  }

}

若使用comparator的方式的话,User类不需要改造,直接定义一个比较器UserComparator:

import java.util.Arrays;
import java.util.Comparator;

public class UserComparator implements Comparator {

  public int compare(Object o1, Object o2) {
    return ((User) o1).getAge() - ((User) o2).getAge();
  }

  /**
   * 测试方法
   */
  public static void main(String[] args) {
    User[] users = new User[] { new User("a", 30), new User("b", 20) };
	Arrays.sort(users, new UserComparator()); //调用比较器
    for (int i = 0; i < users.length; i++) {
      User user = users[i];
      System.out.println(user.getId() + " " + user.getAge());
    }
  }

}

这两个方法的总结

一个类实现了Camparable接口则表明这个类的对象之间是可以相互比较的,这个类对象组成的集合就可以直接使用sort方法排序。 
Comparator可以看成一种算法的实现,将算法和数据分离,Comparator也可以在下面两种环境下使用: 
1、类的设计师没有考虑到比较问题而没有实现Comparable,可以通过Comparator来实现排序而不必改变对象本身 
2、可以使用多种排序标准,比如升序、降序等



                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值