在 Java 中经常会涉及到对象数组之间的排序。言外之意,对象之间需要比出大小并且排除,不仅仅是返回布尔类型,那么就涉及到对象的比较问题。
目录
实现对象排序的两种接口
自然排序:java . lang . Comparable
定制排序:java . util . Comparator
Comparable自然排序
1. 像 String 、包装类等实现了 Comparable 接口,重写了 compareTo(obj)方法,重写之后的对象之间进行从小到大的排列
public class MyTest {
@Test
public void test() {
String [] arr = new String[]{"D","A","C","B"};
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));
}
}
>>> [A, B, C, D]
2. 对于自定义类来说,如果需要排序,我们可以让自定义类实现 Comparable 接口,重写 compareTo(obj),指明如何排序
3. 重写 compareTo(obj)的规则:
如果当前对象 this 大于形参对象 obj ,则返回正整数
如果当前对象 this 小于形参对象 obj ,则返回负整数
如果当前对象 this 等于形参对象 obj ,则返回零
import java.util.Arrays;
public class ComparableTeat {
public static void main(String[] args) {
Goods[] arr = new Goods[4];
arr[0] = new Goods("apple",10);
arr[1] = new Goods("banana",20);
arr[2] = new Goods("mango",30);
arr[3] = new Goods("pear",40);
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));
}
}
class Goods implements Comparable{ //实现比较器接口
private String name;
private double price;
public Goods(){
}
public Goods(String name, double price) {
this.name = name;
this.price = price;
}
public String getName() {
return name;
}
public double getPrice() {
return price;
}
//指明商品比较大小的方式:按照价格从低到高排序
@Override
public int compareTo(Object o) {
if (o instanceof Goods){
Goods goods = (Goods)o;
if (this.price > goods.price){
return 1;
}else if (this.price < goods.price){
return -1;
}else{
return 0;
}
}
throw new RuntimeException("传入的数据类型不一致");
}
@Override
public String toString() {
return "Goods{" +
"name='" + name + '\'' +
", price=" + price +
'}';
}
}
>>> [Goods{name='apple', price=10.0}, Goods{name='banana', price=20.0}, Goods{name='mango', price=30.0}, Goods{name='pear', price=40.0}]
Comparator定制排序
当元素的类型没有实现 java . lang . Comparable 接口而又不方便修改代码,或者实现了 java . lang . Comparable 接口的排序规则不适合当前的操作,那么可以考虑使用 Comparator 的对象来排序,强行对多个对象进行整体排序的比较
import org.junit.Test;
import java.util.Arrays;
import java.util.Comparator;
//数据由高到低排序
public class MyTest {
@Test
public void test() {
String [] arr = new String[]{"D","A","C","B"};
Arrays.sort(arr, new Comparator() {
@Override
public int compare(Object o1, Object o2){
if (o1 instanceof String && o2 instanceof String){
String s1 = (String) o1;
String s2 = (String) o2;
return -s1.compareTo(s2);
}
throw new RuntimeException("数据类型不一致");
}
});
System.out.println(Arrays.toString(arr));
}
}
>>> [D, C, B, A]
Comparable与Comparator的使用对比
Comparable 接口的方式一旦一定,保证 Comparable 接口实现类的对象在任何位置都可以比较大小,而 Comparator 接口属于临时性的比较