java中comparator与comparable的解析

本文详细解析了Java中comparable与comparator的区别与用法。通过具体实例展示了如何使用这两种方式来实现类的排序,包括升序与降序,并介绍了它们在实际应用中的不同场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[size=large] java中comparator与comparable的解析[/size]
一.comparable与comparator的不同点
1.首先comparable是在java.lang包下的接口,而comparator是java.util包下的接口。
2.类实现comparable接口后需要实现下面的方法:
	
public int compareTo(T o) {
// TODO Auto-generated method stub

return 0 ;
}

而实现Comparator的类,测需要实现下面的方法:
		
public int compare(Object o1, Objecto2) {
// TODO Auto-generated method stub

return 0;
}

3.实现comparable的接口的类,它的对象就可以进行自比较,通过Arrays.sort()或Collections.sort()就可以对包含此对象的数组或集合进行排序。看下面例子:
首先,先定义一个Person类,实现Comparable接口,我们以年龄作为排序的依据:

public class Person<T> implements Comparable<T> {

private String name;

private String sex;

private int age;

public String getName() {
return name;
}

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

public String getSex() {
return sex;
}

public void setSex(String sex) {
this.sex = sex;
}

public Person(String name, String sex, int age) {
super();
this.name = name;
this.sex = sex;
this.age = age;
}

public int getAge() {
return age;
}

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

@Override
public int compareTo(T o) {
// TODO Auto-generated method stub

return ((Person)o).getAge() - this.age ;
}

}

然后,定义一个测试类,如下:

public class TestCompare {

public static void main(String[] args){
List<Person> list = new ArrayList<Person>();
Person p1 = new Person("a","male",1);
Person p2 = new Person("b","female",2);
Person p3 = new Person("c","male",3);

list.add(p3);
list.add(p1);
list.add(p2);

Collections.sort(list);

for(Person p:list){
System.out.println("Name: " + p.getName() + " "
+ "Sex: " + p.getSex() + " " + "Age: " + p.getAge());
}

}

输出结果为:
[list]
Name: c Sex: male Age: 3
Name: b Sex: female Age: 2
Name: a Sex: male Age: 1
[/list]
这是是降序排列,把compareTo中的方法做如下改动,就变成升序排列了。
	
public int compareTo(T o) {
// TODO Auto-generated method stub

return this.age - ((Person)o).getAge() ;
}

4.有时类并没有实现comparable接口,而我们又需要对包含此类对象的数组或集合进行排序,那么我们就需要实现Comparator这个比较器了。新建一个person类:

public class Person<T> {

private String name;

private String sex;

private int age;

public String getName() {
return name;
}

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

public String getSex() {
return sex;
}

public void setSex(String sex) {
this.sex = sex;
}

public Person(String name, String sex, int age) {
super();
this.name = name;
this.sex = sex;
this.age = age;
}

public int getAge() {
return age;
}

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

}

再定义一个测试类:

public class TestCompare {

public static void main(String[] args){
List<Person> list = new ArrayList<Person>();
Person p1 = new Person("a","male",1);
Person p2 = new Person("b","female",2);
Person p3 = new Person("c","male",3);

list.add(p3);
list.add(p1);
list.add(p2);

Collections.sort(list , emCpmpare);

for(Person p:list){
System.out.println("Name: " + p.getName() + " "
+ "Sex: " + p.getSex() + " " + "Age: " + p.getAge());
}
}

public static Comparator<Person> emCpmpare = new Comparator<Person>(){

@Override
public int compare(Person o1, Person o2) {
// TODO Auto-generated method stub
String name1 = ((Person)o1).getName();
String name2 = ((Person)o2).getName();
if(!name1.isEmpty() && !name2.isEmpty())
return name1.compareTo(name2);
else {
int age1 = ((Person)o1).getAge();
int age2 = ((Person)o2).getAge();
return age1 - age2;
}
}

};


}

这样就可以实现person的排序了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值