comparable 和 comparator 总结

本文详细介绍了Java中两种常用的排序方式:Comparable与Comparator的使用方法及区别。通过具体实例展示了如何实现Comparable接口进行对象排序,以及如何自定义Comparator来实现灵活的排序逻辑。

comparable :

让需要进行排序的对象实现Comparable接口,重写其中的compareTo(T o)方法,在其中定义排序规则,那么就可以直接调用

java.util.Arrays.sort()来排序对象数组

	比较此对象与指定对象的顺序。如果该对象小于、等于或大于指定对象,则分别返回负整数、零或正整数。
class Student implements Comparable<Student> {
	private String name;
	private int age;
	private float score;


	public Student(String name, int age, float score) {
		this.name = name;
		this.age = age;
		this.score = score;
	}


	public String toString() {
		return name +"***"+ age +"***"+ score;
	}


	@Override
	public int compareTo(Student o) {
		// score是private的,为什么能够直接调用,这是因为在Student类内部
		if (this.score > o.score)
			return -1;// 由高到底排序
		else if (this.score < o.score)
			return 1;
		else {
			if (this.age > o.age)
				return 1;// 由底到高排序
			else if (this.age < o.age)
				return -1;
			else
				return 0;
		}
	}
}


public class ComparableTest{


	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Student stu[] = { 
				new Student("张三", 20, 90.0f), 
				new Student("李四", 22, 90.0f),
				new Student("王五", 20, 99.0f), 
				new Student("赵六", 22, 100.0f) 
				};

		
		for (Student s : stu) {
			System.out.println(s);
		}
		System.out.println("************");
java.util.Arrays.sort(stu); for (Student s : stu) { System.out.println(s); } }}
结果:
张三***20***95.0
李四***22***90.0
王五***20***99.0
赵六***22***100.0
************
赵六***22***100.0
王五***20***99.0
张三***20***95.0
李四***22***90.0
comparator:
public class Person {


private String name;
private int age;


public Person() {


}


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


public String getName() {
return name;
}


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


public int getAge() {
return age;
}


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


@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
}
import java.util.Comparator;


public class PersonComparator implements Comparator<Person>{


	@Override
	public int compare(Person o1, Person o2) {
		if(o1.getAge()>o2.getAge()){
			return 1;
		}else if(o1.getAge()<o2.getAge()){
			return -1;
		}
		return 0;
	}


}

import java.util.Arrays;
public class ComparatorTest {
	 public static void main(String[] args) {
           Person[] persons = {
                   new Person("P1", 50),
                   new Person("P2", 30),
                   new Person("P3", 40)
        };
          
         System.out.println(Arrays.toString(persons));
         
         Arrays.sort(persons, new PersonComparator());
         
       System.out.println(Arrays.toString(persons));
       }
	 	
 }
结果:
[Person [name=P1, age=50], Person [name=P2, age=30], Person [name=P3, age=40]]
[Person [name=P2, age=30], Person [name=P3, age=40], Person [name=P1, age=50]]

总结:

comparable 和 comparator都是接口
comparable 在类中
comparator 类外类中没有变化

引用别人:comparator是策略模式的一种实现

策略模式:策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法独立于使用它的客户而独立变化
引用地址:http://www.blogjava.net/jjshcc/archive/2011/04/12/348132.html

Java 中,Comparable Comparator 都是用于对对象进行比较的接口,使用这两个接口,可以对集合中的元素进行排序、查找、去重等操作。二者的区别如下: - **实现位置**:Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序。若想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法[^3]。 - **代码维护性**:如果一个类实现了 Comparable 接口,并且在多个地方被使用,那么修改比较逻辑可能会影响到所有使用该类的地方,这可能会导致代码的维护成本增加。但是,如果比较逻辑相对稳定,并且在整个应用程序中都是一致的,那么使用 Comparable 可以使代码更加简洁直观。而 Comparator 无需修改原有类,也就是说,通过 Comparator 接口可以实现原有类的解耦,在不修改原有类的情况下,实现排序功能,所以 Comparator 可以看做对外提供排序的接口[^4][^5]。 下面是使用 Comparable Comparator 进行排序的示例代码: ```java import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; // 实现 Comparable 接口 class Person implements Comparable<Person> { private int id; private int age; private String name; public Person(int id, int age, String name) { this.id = id; this.age = age; this.name = name; } // 实现 compareTo 方法 @Override public int compareTo(Person other) { return Integer.compare(this.age, other.age); } public int getAge() { return age; } @Override public String toString() { return "Person{age=" + age + ", name='" + name + "'}"; } } public class ComparisonExample { public static void main(String[] args) { ArrayList<Person> personList = new ArrayList<>(); personList.add(new Person(1, 25, "Alice")); personList.add(new Person(2, 20, "Bob")); personList.add(new Person(3, 30, "Charlie")); // 使用 Comparable 排序 Collections.sort(personList); System.out.println("Using Comparable: " + personList); // 使用 Comparator 排序 Comparator<Person> nameComparator = Comparator.comparing(p -> p.toString()); Collections.sort(personList, nameComparator); System.out.println("Using Comparator: " + personList); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值