在Java中经常会涉及到对象数组的排序问题,那么就涉及到对象之间的比较问题。
Java实现对象排序的方式有两种:
- 自然排序:java.lang.Comparable
- 定制排序:java.util.Comparator
import java.util.Arrays;
/**
* @author HPF
*Comparable接口的使用举例:
*1.像String、包装类等实现了Comparable接口,重写了compareTo(obj)方法,给出了比较两个对象大小的方式。
*2.重写compareTo(obj)方法的规则:
* 如果当前对象this大于形参对象obj,则返回正整数;
* 如果当前对象this小于形参对象obj,则返回负整数;
* 如果当前对象this等于形参对象obj,则返回零。
*/
public class CompareTest {
public static void main(String[] args) {
String[] strings = new String[] {"sdfs","sfs","hhd","fgrgw"};
Arrays.sort(strings);
for (String string : strings) {
System.out.println(string);
}
}
}
import java.util.Arrays;
/**
* @author HPF
*Comparable接口的使用举例:
*1.像String、包装类等实现了Comparable接口,重写了compareTo(obj)方法,给出了比较两个对象大小的方式。
*2.重写compareTo(obj)方法的规则:
* 如果当前对象this大于形参对象obj,则返回正整数;
* 如果当前对象this小于形参对象obj,则返回负整数;
* 如果当前对象this等于形参对象obj,则返回零。
*/
//商品类
class Goods implements Comparable{
private String brand;
private int price;
public Goods(String brand,int price) {
this.brand = brand;
this.price = price;
}
@Override
public int compareTo(Object o) {
if(o instanceof Goods) {
Goods good = (Goods)o;
return this.price - good.price;
}
return 0;
}
@Override
public String toString() {
return brand+":"+price;
}
}
public class CompareTest {
public static void main(String[] args) {
Goods[] goods = new Goods[4];
goods[0] = new Goods("lenovo",22);
goods[1] = new Goods("dell",34);
goods[2] = new Goods("xiaomi",12);
goods[3] = new Goods("huawei",60);
Arrays.sort(goods);
System.out.println(Arrays.toString(goods));
}
}
Comparator接口的使用:定制排序
1.背景:
当元素的类型没有实现java.lang.Comparable接口而又不方便修改代码,或者实现了java.lang.Comparable接口的排序规则不适合当前的操作,那么可以考虑使用 Comparator 的对象来排序;
2.重写compare(object o1,object o2)方法,比较o1和o2的大小;
如果方法返回正整数,则表示o1大于o2;
如果返回0,表示相等;
返回负整数,表示o1小于o2。
import java.util.Arrays;
import java.util.Comparator;
/**
* @author HPF
*Comparable接口的使用举例:
*1.像String、包装类等实现了Comparable接口,重写了compareTo(obj)方法,给出了比较两个对象大小的方式。
*2.重写compareTo(obj)方法的规则:
* 如果当前对象this大于形参对象obj,则返回正整数;
* 如果当前对象this小于形参对象obj,则返回负整数;
* 如果当前对象this等于形参对象obj,则返回零。
*/
public class CompareTest {
public static void main(String[] args) {
String[] strings = new String[] {"sdfs","sfs","hhd","fgrgw"};
//自定义字符串数组从大到小排序
Arrays.sort(strings,new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return -o1.compareTo(o2);
}
});
System.out.println(Arrays.toString(strings));
}
}